blob: 2d343f76f26721302873472a33ba64154c6c6004 [file] [log] [blame]
// Copyright 2018 Google Inc. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Code generated file. DO NOT EDIT.
// Package calendar provides access to the Calendar API.
//
// See https://developers.google.com/google-apps/calendar/firstapp
//
// Usage example:
//
// import "google.golang.org/api/calendar/v3"
// ...
// calendarService, err := calendar.New(oauthHttpClient)
package calendar // import "google.golang.org/api/calendar/v3"
import (
"bytes"
"context"
"encoding/json"
"errors"
"fmt"
"io"
"net/http"
"net/url"
"strconv"
"strings"
gensupport "google.golang.org/api/gensupport"
googleapi "google.golang.org/api/googleapi"
)
// Always reference these packages, just in case the auto-generated code
// below doesn't.
var _ = bytes.NewBuffer
var _ = strconv.Itoa
var _ = fmt.Sprintf
var _ = json.NewDecoder
var _ = io.Copy
var _ = url.Parse
var _ = gensupport.MarshalJSON
var _ = googleapi.Version
var _ = errors.New
var _ = strings.Replace
var _ = context.Canceled
const apiId = "calendar:v3"
const apiName = "calendar"
const apiVersion = "v3"
const basePath = "https://www.googleapis.com/calendar/v3/"
// OAuth2 scopes used by this API.
const (
// See, edit, share, and permanently delete all the calendars you can
// access using Google Calendar
CalendarScope = "https://www.googleapis.com/auth/calendar"
// View and edit events on all your calendars
CalendarEventsScope = "https://www.googleapis.com/auth/calendar.events"
// View events on all your calendars
CalendarEventsReadonlyScope = "https://www.googleapis.com/auth/calendar.events.readonly"
// View your calendars
CalendarReadonlyScope = "https://www.googleapis.com/auth/calendar.readonly"
// View your Calendar settings
CalendarSettingsReadonlyScope = "https://www.googleapis.com/auth/calendar.settings.readonly"
)
func New(client *http.Client) (*Service, error) {
if client == nil {
return nil, errors.New("client is nil")
}
s := &Service{client: client, BasePath: basePath}
s.Acl = NewAclService(s)
s.CalendarList = NewCalendarListService(s)
s.Calendars = NewCalendarsService(s)
s.Channels = NewChannelsService(s)
s.Colors = NewColorsService(s)
s.Events = NewEventsService(s)
s.Freebusy = NewFreebusyService(s)
s.Settings = NewSettingsService(s)
return s, nil
}
type Service struct {
client *http.Client
BasePath string // API endpoint base URL
UserAgent string // optional additional User-Agent fragment
Acl *AclService
CalendarList *CalendarListService
Calendars *CalendarsService
Channels *ChannelsService
Colors *ColorsService
Events *EventsService
Freebusy *FreebusyService
Settings *SettingsService
}
func (s *Service) userAgent() string {
if s.UserAgent == "" {
return googleapi.UserAgent
}
return googleapi.UserAgent + " " + s.UserAgent
}
func NewAclService(s *Service) *AclService {
rs := &AclService{s: s}
return rs
}
type AclService struct {
s *Service
}
func NewCalendarListService(s *Service) *CalendarListService {
rs := &CalendarListService{s: s}
return rs
}
type CalendarListService struct {
s *Service
}
func NewCalendarsService(s *Service) *CalendarsService {
rs := &CalendarsService{s: s}
return rs
}
type CalendarsService struct {
s *Service
}
func NewChannelsService(s *Service) *ChannelsService {
rs := &ChannelsService{s: s}
return rs
}
type ChannelsService struct {
s *Service
}
func NewColorsService(s *Service) *ColorsService {
rs := &ColorsService{s: s}
return rs
}
type ColorsService struct {
s *Service
}
func NewEventsService(s *Service) *EventsService {
rs := &EventsService{s: s}
return rs
}
type EventsService struct {
s *Service
}
func NewFreebusyService(s *Service) *FreebusyService {
rs := &FreebusyService{s: s}
return rs
}
type FreebusyService struct {
s *Service
}
func NewSettingsService(s *Service) *SettingsService {
rs := &SettingsService{s: s}
return rs
}
type SettingsService struct {
s *Service
}
type Acl struct {
// Etag: ETag of the collection.
Etag string `json:"etag,omitempty"`
// Items: List of rules on the access control list.
Items []*AclRule `json:"items,omitempty"`
// Kind: Type of the collection ("calendar#acl").
Kind string `json:"kind,omitempty"`
// NextPageToken: Token used to access the next page of this result.
// Omitted if no further results are available, in which case
// nextSyncToken is provided.
NextPageToken string `json:"nextPageToken,omitempty"`
// NextSyncToken: Token used at a later point in time to retrieve only
// the entries that have changed since this result was returned. Omitted
// if further results are available, in which case nextPageToken is
// provided.
NextSyncToken string `json:"nextSyncToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Etag") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Etag") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Acl) MarshalJSON() ([]byte, error) {
type NoMethod Acl
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type AclRule struct {
// Etag: ETag of the resource.
Etag string `json:"etag,omitempty"`
// Id: Identifier of the ACL rule.
Id string `json:"id,omitempty"`
// Kind: Type of the resource ("calendar#aclRule").
Kind string `json:"kind,omitempty"`
// Role: The role assigned to the scope. Possible values are:
// - "none" - Provides no access.
// - "freeBusyReader" - Provides read access to free/busy information.
//
// - "reader" - Provides read access to the calendar. Private events
// will appear to users with reader access, but event details will be
// hidden.
// - "writer" - Provides read and write access to the calendar. Private
// events will appear to users with writer access, and event details
// will be visible.
// - "owner" - Provides ownership of the calendar. This role has all of
// the permissions of the writer role with the additional ability to see
// and manipulate ACLs.
Role string `json:"role,omitempty"`
// Scope: The scope of the rule.
Scope *AclRuleScope `json:"scope,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Etag") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Etag") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *AclRule) MarshalJSON() ([]byte, error) {
type NoMethod AclRule
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// AclRuleScope: The scope of the rule.
type AclRuleScope struct {
// Type: The type of the scope. Possible values are:
// - "default" - The public scope. This is the default value.
// - "user" - Limits the scope to a single user.
// - "group" - Limits the scope to a group.
// - "domain" - Limits the scope to a domain. Note: The permissions
// granted to the "default", or public, scope apply to any user,
// authenticated or not.
Type string `json:"type,omitempty"`
// Value: The email address of a user or group, or the name of a domain,
// depending on the scope type. Omitted for type "default".
Value string `json:"value,omitempty"`
// ForceSendFields is a list of field names (e.g. "Type") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Type") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *AclRuleScope) MarshalJSON() ([]byte, error) {
type NoMethod AclRuleScope
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Calendar struct {
// ConferenceProperties: Conferencing properties for this calendar, for
// example what types of conferences are allowed.
ConferenceProperties *ConferenceProperties `json:"conferenceProperties,omitempty"`
// Description: Description of the calendar. Optional.
Description string `json:"description,omitempty"`
// Etag: ETag of the resource.
Etag string `json:"etag,omitempty"`
// Id: Identifier of the calendar. To retrieve IDs call the
// calendarList.list() method.
Id string `json:"id,omitempty"`
// Kind: Type of the resource ("calendar#calendar").
Kind string `json:"kind,omitempty"`
// Location: Geographic location of the calendar as free-form text.
// Optional.
Location string `json:"location,omitempty"`
// Summary: Title of the calendar.
Summary string `json:"summary,omitempty"`
// TimeZone: The time zone of the calendar. (Formatted as an IANA Time
// Zone Database name, e.g. "Europe/Zurich".) Optional.
TimeZone string `json:"timeZone,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g.
// "ConferenceProperties") to unconditionally include in API requests.
// By default, fields with empty values are omitted from API requests.
// However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "ConferenceProperties") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *Calendar) MarshalJSON() ([]byte, error) {
type NoMethod Calendar
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type CalendarList struct {
// Etag: ETag of the collection.
Etag string `json:"etag,omitempty"`
// Items: Calendars that are present on the user's calendar list.
Items []*CalendarListEntry `json:"items,omitempty"`
// Kind: Type of the collection ("calendar#calendarList").
Kind string `json:"kind,omitempty"`
// NextPageToken: Token used to access the next page of this result.
// Omitted if no further results are available, in which case
// nextSyncToken is provided.
NextPageToken string `json:"nextPageToken,omitempty"`
// NextSyncToken: Token used at a later point in time to retrieve only
// the entries that have changed since this result was returned. Omitted
// if further results are available, in which case nextPageToken is
// provided.
NextSyncToken string `json:"nextSyncToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Etag") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Etag") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *CalendarList) MarshalJSON() ([]byte, error) {
type NoMethod CalendarList
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type CalendarListEntry struct {
// AccessRole: The effective access role that the authenticated user has
// on the calendar. Read-only. Possible values are:
// - "freeBusyReader" - Provides read access to free/busy information.
//
// - "reader" - Provides read access to the calendar. Private events
// will appear to users with reader access, but event details will be
// hidden.
// - "writer" - Provides read and write access to the calendar. Private
// events will appear to users with writer access, and event details
// will be visible.
// - "owner" - Provides ownership of the calendar. This role has all of
// the permissions of the writer role with the additional ability to see
// and manipulate ACLs.
AccessRole string `json:"accessRole,omitempty"`
// BackgroundColor: The main color of the calendar in the hexadecimal
// format "#0088aa". This property supersedes the index-based colorId
// property. To set or change this property, you need to specify
// colorRgbFormat=true in the parameters of the insert, update and patch
// methods. Optional.
BackgroundColor string `json:"backgroundColor,omitempty"`
// ColorId: The color of the calendar. This is an ID referring to an
// entry in the calendar section of the colors definition (see the
// colors endpoint). This property is superseded by the backgroundColor
// and foregroundColor properties and can be ignored when using these
// properties. Optional.
ColorId string `json:"colorId,omitempty"`
// ConferenceProperties: Conferencing properties for this calendar, for
// example what types of conferences are allowed.
ConferenceProperties *ConferenceProperties `json:"conferenceProperties,omitempty"`
// DefaultReminders: The default reminders that the authenticated user
// has for this calendar.
DefaultReminders []*EventReminder `json:"defaultReminders,omitempty"`
// Deleted: Whether this calendar list entry has been deleted from the
// calendar list. Read-only. Optional. The default is False.
Deleted bool `json:"deleted,omitempty"`
// Description: Description of the calendar. Optional. Read-only.
Description string `json:"description,omitempty"`
// Etag: ETag of the resource.
Etag string `json:"etag,omitempty"`
// ForegroundColor: The foreground color of the calendar in the
// hexadecimal format "#ffffff". This property supersedes the
// index-based colorId property. To set or change this property, you
// need to specify colorRgbFormat=true in the parameters of the insert,
// update and patch methods. Optional.
ForegroundColor string `json:"foregroundColor,omitempty"`
// Hidden: Whether the calendar has been hidden from the list. Optional.
// The default is False.
Hidden bool `json:"hidden,omitempty"`
// Id: Identifier of the calendar.
Id string `json:"id,omitempty"`
// Kind: Type of the resource ("calendar#calendarListEntry").
Kind string `json:"kind,omitempty"`
// Location: Geographic location of the calendar as free-form text.
// Optional. Read-only.
Location string `json:"location,omitempty"`
// NotificationSettings: The notifications that the authenticated user
// is receiving for this calendar.
NotificationSettings *CalendarListEntryNotificationSettings `json:"notificationSettings,omitempty"`
// Primary: Whether the calendar is the primary calendar of the
// authenticated user. Read-only. Optional. The default is False.
Primary bool `json:"primary,omitempty"`
// Selected: Whether the calendar content shows up in the calendar UI.
// Optional. The default is False.
Selected bool `json:"selected,omitempty"`
// Summary: Title of the calendar. Read-only.
Summary string `json:"summary,omitempty"`
// SummaryOverride: The summary that the authenticated user has set for
// this calendar. Optional.
SummaryOverride string `json:"summaryOverride,omitempty"`
// TimeZone: The time zone of the calendar. Optional. Read-only.
TimeZone string `json:"timeZone,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "AccessRole") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AccessRole") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *CalendarListEntry) MarshalJSON() ([]byte, error) {
type NoMethod CalendarListEntry
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// CalendarListEntryNotificationSettings: The notifications that the
// authenticated user is receiving for this calendar.
type CalendarListEntryNotificationSettings struct {
// Notifications: The list of notifications set for this calendar.
Notifications []*CalendarNotification `json:"notifications,omitempty"`
// ForceSendFields is a list of field names (e.g. "Notifications") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Notifications") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *CalendarListEntryNotificationSettings) MarshalJSON() ([]byte, error) {
type NoMethod CalendarListEntryNotificationSettings
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type CalendarNotification struct {
// Method: The method used to deliver the notification. Possible values
// are:
// - "email" - Notifications are sent via email.
// - "sms" - Deprecated. Once this feature is shutdown, the API will no
// longer return notifications using this method. Any newly added SMS
// notifications will be ignored. See Google Calendar SMS notifications
// to be removed for more information.
// Notifications are sent via SMS. This value is read-only and is
// ignored on inserts and updates. SMS notifications are only available
// for G Suite customers.
// Required when adding a notification.
Method string `json:"method,omitempty"`
// Type: The type of notification. Possible values are:
// - "eventCreation" - Notification sent when a new event is put on the
// calendar.
// - "eventChange" - Notification sent when an event is changed.
// - "eventCancellation" - Notification sent when an event is cancelled.
//
// - "eventResponse" - Notification sent when an attendee responds to
// the event invitation.
// - "agenda" - An agenda with the events of the day (sent out in the
// morning).
// Required when adding a notification.
Type string `json:"type,omitempty"`
// ForceSendFields is a list of field names (e.g. "Method") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Method") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *CalendarNotification) MarshalJSON() ([]byte, error) {
type NoMethod CalendarNotification
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Channel struct {
// Address: The address where notifications are delivered for this
// channel.
Address string `json:"address,omitempty"`
// Expiration: Date and time of notification channel expiration,
// expressed as a Unix timestamp, in milliseconds. Optional.
Expiration int64 `json:"expiration,omitempty,string"`
// Id: A UUID or similar unique string that identifies this channel.
Id string `json:"id,omitempty"`
// Kind: Identifies this as a notification channel used to watch for
// changes to a resource. Value: the fixed string "api#channel".
Kind string `json:"kind,omitempty"`
// Params: Additional parameters controlling delivery channel behavior.
// Optional.
Params map[string]string `json:"params,omitempty"`
// Payload: A Boolean value to indicate whether payload is wanted.
// Optional.
Payload bool `json:"payload,omitempty"`
// ResourceId: An opaque ID that identifies the resource being watched
// on this channel. Stable across different API versions.
ResourceId string `json:"resourceId,omitempty"`
// ResourceUri: A version-specific identifier for the watched resource.
ResourceUri string `json:"resourceUri,omitempty"`
// Token: An arbitrary string delivered to the target address with each
// notification delivered over this channel. Optional.
Token string `json:"token,omitempty"`
// Type: The type of delivery mechanism used for this channel.
Type string `json:"type,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Address") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Address") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Channel) MarshalJSON() ([]byte, error) {
type NoMethod Channel
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ColorDefinition struct {
// Background: The background color associated with this color
// definition.
Background string `json:"background,omitempty"`
// Foreground: The foreground color that can be used to write on top of
// a background with 'background' color.
Foreground string `json:"foreground,omitempty"`
// ForceSendFields is a list of field names (e.g. "Background") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Background") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ColorDefinition) MarshalJSON() ([]byte, error) {
type NoMethod ColorDefinition
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Colors struct {
// Calendar: A global palette of calendar colors, mapping from the color
// ID to its definition. A calendarListEntry resource refers to one of
// these color IDs in its color field. Read-only.
Calendar map[string]ColorDefinition `json:"calendar,omitempty"`
// Event: A global palette of event colors, mapping from the color ID to
// its definition. An event resource may refer to one of these color IDs
// in its color field. Read-only.
Event map[string]ColorDefinition `json:"event,omitempty"`
// Kind: Type of the resource ("calendar#colors").
Kind string `json:"kind,omitempty"`
// Updated: Last modification time of the color palette (as a RFC3339
// timestamp). Read-only.
Updated string `json:"updated,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Calendar") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Calendar") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Colors) MarshalJSON() ([]byte, error) {
type NoMethod Colors
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceData struct {
// ConferenceId: The ID of the conference.
// Can be used by developers to keep track of conferences, should not be
// displayed to users.
// Values for solution types:
// - "eventHangout": unset.
// - "eventNamedHangout": the name of the Hangout.
// - "hangoutsMeet": the 10-letter meeting code, for example
// "aaa-bbbb-ccc". Optional.
ConferenceId string `json:"conferenceId,omitempty"`
// ConferenceSolution: The conference solution, such as Hangouts or
// Hangouts Meet.
// Unset for a conference with a failed create request.
// Either conferenceSolution and at least one entryPoint, or
// createRequest is required.
ConferenceSolution *ConferenceSolution `json:"conferenceSolution,omitempty"`
// CreateRequest: A request to generate a new conference and attach it
// to the event. The data is generated asynchronously. To see whether
// the data is present check the status field.
// Either conferenceSolution and at least one entryPoint, or
// createRequest is required.
CreateRequest *CreateConferenceRequest `json:"createRequest,omitempty"`
// EntryPoints: Information about individual conference entry points,
// such as URLs or phone numbers.
// All of them must belong to the same conference.
// Either conferenceSolution and at least one entryPoint, or
// createRequest is required.
EntryPoints []*EntryPoint `json:"entryPoints,omitempty"`
// Notes: Additional notes (such as instructions from the domain
// administrator, legal notices) to display to the user. Can contain
// HTML. The maximum length is 2048 characters. Optional.
Notes string `json:"notes,omitempty"`
// Parameters: Additional properties related to a conference. An example
// would be a solution-specific setting for enabling video streaming.
Parameters *ConferenceParameters `json:"parameters,omitempty"`
// Signature: The signature of the conference data.
// Genereated on server side. Must be preserved while copying the
// conference data between events, otherwise the conference data will
// not be copied.
// Unset for a conference with a failed create request.
// Optional for a conference with a pending create request.
Signature string `json:"signature,omitempty"`
// ForceSendFields is a list of field names (e.g. "ConferenceId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "ConferenceId") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceData) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceData
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceParameters struct {
// AddOnParameters: Additional add-on specific data.
AddOnParameters *ConferenceParametersAddOnParameters `json:"addOnParameters,omitempty"`
// ForceSendFields is a list of field names (e.g. "AddOnParameters") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AddOnParameters") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *ConferenceParameters) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceParameters
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceParametersAddOnParameters struct {
Parameters map[string]string `json:"parameters,omitempty"`
// ForceSendFields is a list of field names (e.g. "Parameters") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Parameters") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceParametersAddOnParameters) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceParametersAddOnParameters
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceProperties struct {
// AllowedConferenceSolutionTypes: The types of conference solutions
// that are supported for this calendar.
// The possible values are:
// - "eventHangout"
// - "eventNamedHangout"
// - "hangoutsMeet" Optional.
AllowedConferenceSolutionTypes []string `json:"allowedConferenceSolutionTypes,omitempty"`
// ForceSendFields is a list of field names (e.g.
// "AllowedConferenceSolutionTypes") to unconditionally include in API
// requests. By default, fields with empty values are omitted from API
// requests. However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g.
// "AllowedConferenceSolutionTypes") to include in API requests with the
// JSON null value. By default, fields with empty values are omitted
// from API requests. However, any field with an empty value appearing
// in NullFields will be sent to the server as null. It is an error if a
// field in this list has a non-empty value. This may be used to include
// null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceProperties) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceProperties
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceRequestStatus struct {
// StatusCode: The current status of the conference create request.
// Read-only.
// The possible values are:
// - "pending": the conference create request is still being
// processed.
// - "success": the conference create request succeeded, the entry
// points are populated.
// - "failure": the conference create request failed, there are no entry
// points.
StatusCode string `json:"statusCode,omitempty"`
// ForceSendFields is a list of field names (e.g. "StatusCode") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "StatusCode") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceRequestStatus) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceRequestStatus
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceSolution struct {
// IconUri: The user-visible icon for this solution.
IconUri string `json:"iconUri,omitempty"`
// Key: The key which can uniquely identify the conference solution for
// this event.
Key *ConferenceSolutionKey `json:"key,omitempty"`
// Name: The user-visible name of this solution. Not localized.
Name string `json:"name,omitempty"`
// ForceSendFields is a list of field names (e.g. "IconUri") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "IconUri") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceSolution) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceSolution
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type ConferenceSolutionKey struct {
// Type: The conference solution type.
// If a client encounters an unfamiliar or empty type, it should still
// be able to display the entry points. However, it should disallow
// modifications.
// The possible values are:
// - "eventHangout" for Hangouts for consumers
// (http://hangouts.google.com)
// - "eventNamedHangout" for classic Hangouts for G Suite users
// (http://hangouts.google.com)
// - "hangoutsMeet" for Hangouts Meet (http://meet.google.com)
Type string `json:"type,omitempty"`
// ForceSendFields is a list of field names (e.g. "Type") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Type") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *ConferenceSolutionKey) MarshalJSON() ([]byte, error) {
type NoMethod ConferenceSolutionKey
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type CreateConferenceRequest struct {
// ConferenceSolutionKey: The conference solution, such as Hangouts or
// Hangouts Meet.
ConferenceSolutionKey *ConferenceSolutionKey `json:"conferenceSolutionKey,omitempty"`
// RequestId: The client-generated unique ID for this request.
// Clients should regenerate this ID for every new request. If an ID
// provided is the same as for the previous request, the request is
// ignored.
RequestId string `json:"requestId,omitempty"`
// Status: The status of the conference create request.
Status *ConferenceRequestStatus `json:"status,omitempty"`
// ForceSendFields is a list of field names (e.g.
// "ConferenceSolutionKey") to unconditionally include in API requests.
// By default, fields with empty values are omitted from API requests.
// However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "ConferenceSolutionKey") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *CreateConferenceRequest) MarshalJSON() ([]byte, error) {
type NoMethod CreateConferenceRequest
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type EntryPoint struct {
// AccessCode: The access code to access the conference. The maximum
// length is 128 characters.
// When creating new conference data, populate only the subset of
// {meetingCode, accessCode, passcode, password, pin} fields that match
// the terminology that the conference provider uses. Only the populated
// fields should be displayed.
// Optional.
AccessCode string `json:"accessCode,omitempty"`
// EntryPointFeatures: Features of the entry point, such as being toll
// or toll-free. One entry point can have multiple features. However,
// toll and toll-free cannot be both set on the same entry point.
EntryPointFeatures []string `json:"entryPointFeatures,omitempty"`
// EntryPointType: The type of the conference entry point.
// Possible values are:
// - "video" - joining a conference over HTTP. A conference can have
// zero or one video entry point.
// - "phone" - joining a conference by dialing a phone number. A
// conference can have zero or more phone entry points.
// - "sip" - joining a conference over SIP. A conference can have zero
// or one sip entry point.
// - "more" - further conference joining instructions, for example
// additional phone numbers. A conference can have zero or one more
// entry point. A conference with only a more entry point is not a valid
// conference.
EntryPointType string `json:"entryPointType,omitempty"`
// Label: The label for the URI. Visible to end users. Not localized.
// The maximum length is 512 characters.
// Examples:
// - for video: meet.google.com/aaa-bbbb-ccc
// - for phone: +1 123 268 2601
// - for sip: 12345678@altostrat.com
// - for more: should not be filled
// Optional.
Label string `json:"label,omitempty"`
// MeetingCode: The meeting code to access the conference. The maximum
// length is 128 characters.
// When creating new conference data, populate only the subset of
// {meetingCode, accessCode, passcode, password, pin} fields that match
// the terminology that the conference provider uses. Only the populated
// fields should be displayed.
// Optional.
MeetingCode string `json:"meetingCode,omitempty"`
// Passcode: The passcode to access the conference. The maximum length
// is 128 characters.
// When creating new conference data, populate only the subset of
// {meetingCode, accessCode, passcode, password, pin} fields that match
// the terminology that the conference provider uses. Only the populated
// fields should be displayed.
Passcode string `json:"passcode,omitempty"`
// Password: The password to access the conference. The maximum length
// is 128 characters.
// When creating new conference data, populate only the subset of
// {meetingCode, accessCode, passcode, password, pin} fields that match
// the terminology that the conference provider uses. Only the populated
// fields should be displayed.
// Optional.
Password string `json:"password,omitempty"`
// Pin: The PIN to access the conference. The maximum length is 128
// characters.
// When creating new conference data, populate only the subset of
// {meetingCode, accessCode, passcode, password, pin} fields that match
// the terminology that the conference provider uses. Only the populated
// fields should be displayed.
// Optional.
Pin string `json:"pin,omitempty"`
// RegionCode: The CLDR/ISO 3166 region code for the country associated
// with this phone access. Example: "SE" for Sweden.
// Calendar backend will populate this field only for
// EntryPointType.PHONE.
RegionCode string `json:"regionCode,omitempty"`
// Uri: The URI of the entry point. The maximum length is 1300
// characters.
// Format:
// - for video, http: or https: schema is required.
// - for phone, tel: schema is required. The URI should include the
// entire dial sequence (e.g., tel:+12345678900,,,123456789;1234).
// - for sip, sip: schema is required, e.g.,
// sip:12345678@myprovider.com.
// - for more, http: or https: schema is required.
Uri string `json:"uri,omitempty"`
// ForceSendFields is a list of field names (e.g. "AccessCode") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AccessCode") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EntryPoint) MarshalJSON() ([]byte, error) {
type NoMethod EntryPoint
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Error struct {
// Domain: Domain, or broad category, of the error.
Domain string `json:"domain,omitempty"`
// Reason: Specific reason for the error. Some of the possible values
// are:
// - "groupTooBig" - The group of users requested is too large for a
// single query.
// - "tooManyCalendarsRequested" - The number of calendars requested is
// too large for a single query.
// - "notFound" - The requested resource was not found.
// - "internalError" - The API service has encountered an internal
// error. Additional error types may be added in the future, so clients
// should gracefully handle additional error statuses not included in
// this list.
Reason string `json:"reason,omitempty"`
// ForceSendFields is a list of field names (e.g. "Domain") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Domain") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Error) MarshalJSON() ([]byte, error) {
type NoMethod Error
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Event struct {
// AnyoneCanAddSelf: Whether anyone can invite themselves to the event
// (currently works for Google+ events only). Optional. The default is
// False.
AnyoneCanAddSelf bool `json:"anyoneCanAddSelf,omitempty"`
// Attachments: File attachments for the event. Currently only Google
// Drive attachments are supported.
// In order to modify attachments the supportsAttachments request
// parameter should be set to true.
// There can be at most 25 attachments per event,
Attachments []*EventAttachment `json:"attachments,omitempty"`
// Attendees: The attendees of the event. See the Events with attendees
// guide for more information on scheduling events with other calendar
// users.
Attendees []*EventAttendee `json:"attendees,omitempty"`
// AttendeesOmitted: Whether attendees may have been omitted from the
// event's representation. When retrieving an event, this may be due to
// a restriction specified by the maxAttendee query parameter. When
// updating an event, this can be used to only update the participant's
// response. Optional. The default is False.
AttendeesOmitted bool `json:"attendeesOmitted,omitempty"`
// ColorId: The color of the event. This is an ID referring to an entry
// in the event section of the colors definition (see the colors
// endpoint). Optional.
ColorId string `json:"colorId,omitempty"`
// ConferenceData: The conference-related information, such as details
// of a Hangouts Meet conference. To create new conference details use
// the createRequest field. To persist your changes, remember to set the
// conferenceDataVersion request parameter to 1 for all event
// modification requests.
ConferenceData *ConferenceData `json:"conferenceData,omitempty"`
// Created: Creation time of the event (as a RFC3339 timestamp).
// Read-only.
Created string `json:"created,omitempty"`
// Creator: The creator of the event. Read-only.
Creator *EventCreator `json:"creator,omitempty"`
// Description: Description of the event. Optional.
Description string `json:"description,omitempty"`
// End: The (exclusive) end time of the event. For a recurring event,
// this is the end time of the first instance.
End *EventDateTime `json:"end,omitempty"`
// EndTimeUnspecified: Whether the end time is actually unspecified. An
// end time is still provided for compatibility reasons, even if this
// attribute is set to True. The default is False.
EndTimeUnspecified bool `json:"endTimeUnspecified,omitempty"`
// Etag: ETag of the resource.
Etag string `json:"etag,omitempty"`
// ExtendedProperties: Extended properties of the event.
ExtendedProperties *EventExtendedProperties `json:"extendedProperties,omitempty"`
// Gadget: A gadget that extends this event.
Gadget *EventGadget `json:"gadget,omitempty"`
// GuestsCanInviteOthers: Whether attendees other than the organizer can
// invite others to the event. Optional. The default is True.
//
// Default: true
GuestsCanInviteOthers *bool `json:"guestsCanInviteOthers,omitempty"`
// GuestsCanModify: Whether attendees other than the organizer can
// modify the event. Optional. The default is False.
GuestsCanModify bool `json:"guestsCanModify,omitempty"`
// GuestsCanSeeOtherGuests: Whether attendees other than the organizer
// can see who the event's attendees are. Optional. The default is True.
//
// Default: true
GuestsCanSeeOtherGuests *bool `json:"guestsCanSeeOtherGuests,omitempty"`
// HangoutLink: An absolute link to the Google+ hangout associated with
// this event. Read-only.
HangoutLink string `json:"hangoutLink,omitempty"`
// HtmlLink: An absolute link to this event in the Google Calendar Web
// UI. Read-only.
HtmlLink string `json:"htmlLink,omitempty"`
// ICalUID: Event unique identifier as defined in RFC5545. It is used to
// uniquely identify events accross calendaring systems and must be
// supplied when importing events via the import method.
// Note that the icalUID and the id are not identical and only one of
// them should be supplied at event creation time. One difference in
// their semantics is that in recurring events, all occurrences of one
// event have different ids while they all share the same icalUIDs.
ICalUID string `json:"iCalUID,omitempty"`
// Id: Opaque identifier of the event. When creating new single or
// recurring events, you can specify their IDs. Provided IDs must follow
// these rules:
// - characters allowed in the ID are those used in base32hex encoding,
// i.e. lowercase letters a-v and digits 0-9, see section 3.1.2 in
// RFC2938
// - the length of the ID must be between 5 and 1024 characters
// - the ID must be unique per calendar Due to the globally distributed
// nature of the system, we cannot guarantee that ID collisions will be
// detected at event creation time. To minimize the risk of collisions
// we recommend using an established UUID algorithm such as one
// described in RFC4122.
// If you do not specify an ID, it will be automatically generated by
// the server.
// Note that the icalUID and the id are not identical and only one of
// them should be supplied at event creation time. One difference in
// their semantics is that in recurring events, all occurrences of one
// event have different ids while they all share the same icalUIDs.
Id string `json:"id,omitempty"`
// Kind: Type of the resource ("calendar#event").
Kind string `json:"kind,omitempty"`
// Location: Geographic location of the event as free-form text.
// Optional.
Location string `json:"location,omitempty"`
// Locked: Whether this is a locked event copy where no changes can be
// made to the main event fields "summary", "description", "location",
// "start", "end" or "recurrence". The default is False. Read-Only.
Locked bool `json:"locked,omitempty"`
// Organizer: The organizer of the event. If the organizer is also an
// attendee, this is indicated with a separate entry in attendees with
// the organizer field set to True. To change the organizer, use the
// move operation. Read-only, except when importing an event.
Organizer *EventOrganizer `json:"organizer,omitempty"`
// OriginalStartTime: For an instance of a recurring event, this is the
// time at which this event would start according to the recurrence data
// in the recurring event identified by recurringEventId. It uniquely
// identifies the instance within the recurring event series even if the
// instance was moved to a different time. Immutable.
OriginalStartTime *EventDateTime `json:"originalStartTime,omitempty"`
// PrivateCopy: Whether this is a private event copy where changes are
// not shared with other copies on other calendars. Optional. Immutable.
// The default is False.
PrivateCopy bool `json:"privateCopy,omitempty"`
// Recurrence: List of RRULE, EXRULE, RDATE and EXDATE lines for a
// recurring event, as specified in RFC5545. Note that DTSTART and DTEND
// lines are not allowed in this field; event start and end times are
// specified in the start and end fields. This field is omitted for
// single events or instances of recurring events.
Recurrence []string `json:"recurrence,omitempty"`
// RecurringEventId: For an instance of a recurring event, this is the
// id of the recurring event to which this instance belongs. Immutable.
RecurringEventId string `json:"recurringEventId,omitempty"`
// Reminders: Information about the event's reminders for the
// authenticated user.
Reminders *EventReminders `json:"reminders,omitempty"`
// Sequence: Sequence number as per iCalendar.
Sequence int64 `json:"sequence,omitempty"`
// Source: Source from which the event was created. For example, a web
// page, an email message or any document identifiable by an URL with
// HTTP or HTTPS scheme. Can only be seen or modified by the creator of
// the event.
Source *EventSource `json:"source,omitempty"`
// Start: The (inclusive) start time of the event. For a recurring
// event, this is the start time of the first instance.
Start *EventDateTime `json:"start,omitempty"`
// Status: Status of the event. Optional. Possible values are:
// - "confirmed" - The event is confirmed. This is the default status.
//
// - "tentative" - The event is tentatively confirmed.
// - "cancelled" - The event is cancelled (deleted). The list method
// returns cancelled events only on incremental sync (when syncToken or
// updatedMin are specified) or if the showDeleted flag is set to true.
// The get method always returns them.
// A cancelled status represents two different states depending on the
// event type:
// - Cancelled exceptions of an uncancelled recurring event indicate
// that this instance should no longer be presented to the user. Clients
// should store these events for the lifetime of the parent recurring
// event.
// Cancelled exceptions are only guaranteed to have values for the id,
// recurringEventId and originalStartTime fields populated. The other
// fields might be empty.
// - All other cancelled events represent deleted events. Clients should
// remove their locally synced copies. Such cancelled events will
// eventually disappear, so do not rely on them being available
// indefinitely.
// Deleted events are only guaranteed to have the id field populated.
// On the organizer's calendar, cancelled events continue to expose
// event details (summary, location, etc.) so that they can be restored
// (undeleted). Similarly, the events to which the user was invited and
// that they manually removed continue to provide details. However,
// incremental sync requests with showDeleted set to false will not
// return these details.
// If an event changes its organizer (for example via the move
// operation) and the original organizer is not on the attendee list, it
// will leave behind a cancelled event where only the id field is
// guaranteed to be populated.
Status string `json:"status,omitempty"`
// Summary: Title of the event.
Summary string `json:"summary,omitempty"`
// Transparency: Whether the event blocks time on the calendar.
// Optional. Possible values are:
// - "opaque" - Default value. The event does block time on the
// calendar. This is equivalent to setting Show me as to Busy in the
// Calendar UI.
// - "transparent" - The event does not block time on the calendar. This
// is equivalent to setting Show me as to Available in the Calendar UI.
Transparency string `json:"transparency,omitempty"`
// Updated: Last modification time of the event (as a RFC3339
// timestamp). Read-only.
Updated string `json:"updated,omitempty"`
// Visibility: Visibility of the event. Optional. Possible values are:
//
// - "default" - Uses the default visibility for events on the calendar.
// This is the default value.
// - "public" - The event is public and event details are visible to all
// readers of the calendar.
// - "private" - The event is private and only event attendees may view
// event details.
// - "confidential" - The event is private. This value is provided for
// compatibility reasons.
Visibility string `json:"visibility,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "AnyoneCanAddSelf") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AnyoneCanAddSelf") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *Event) MarshalJSON() ([]byte, error) {
type NoMethod Event
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventCreator: The creator of the event. Read-only.
type EventCreator struct {
// DisplayName: The creator's name, if available.
DisplayName string `json:"displayName,omitempty"`
// Email: The creator's email address, if available.
Email string `json:"email,omitempty"`
// Id: The creator's Profile ID, if available. It corresponds to the id
// field in the People collection of the Google+ API
Id string `json:"id,omitempty"`
// Self: Whether the creator corresponds to the calendar on which this
// copy of the event appears. Read-only. The default is False.
Self bool `json:"self,omitempty"`
// ForceSendFields is a list of field names (e.g. "DisplayName") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "DisplayName") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventCreator) MarshalJSON() ([]byte, error) {
type NoMethod EventCreator
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventExtendedProperties: Extended properties of the event.
type EventExtendedProperties struct {
// Private: Properties that are private to the copy of the event that
// appears on this calendar.
Private map[string]string `json:"private,omitempty"`
// Shared: Properties that are shared between copies of the event on
// other attendees' calendars.
Shared map[string]string `json:"shared,omitempty"`
// ForceSendFields is a list of field names (e.g. "Private") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Private") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventExtendedProperties) MarshalJSON() ([]byte, error) {
type NoMethod EventExtendedProperties
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventGadget: A gadget that extends this event.
type EventGadget struct {
// Display: The gadget's display mode. Optional. Possible values are:
//
// - "icon" - The gadget displays next to the event's title in the
// calendar view.
// - "chip" - The gadget displays when the event is clicked.
Display string `json:"display,omitempty"`
// Height: The gadget's height in pixels. The height must be an integer
// greater than 0. Optional.
Height int64 `json:"height,omitempty"`
// IconLink: The gadget's icon URL. The URL scheme must be HTTPS.
IconLink string `json:"iconLink,omitempty"`
// Link: The gadget's URL. The URL scheme must be HTTPS.
Link string `json:"link,omitempty"`
// Preferences: Preferences.
Preferences map[string]string `json:"preferences,omitempty"`
// Title: The gadget's title.
Title string `json:"title,omitempty"`
// Type: The gadget's type.
Type string `json:"type,omitempty"`
// Width: The gadget's width in pixels. The width must be an integer
// greater than 0. Optional.
Width int64 `json:"width,omitempty"`
// ForceSendFields is a list of field names (e.g. "Display") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Display") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventGadget) MarshalJSON() ([]byte, error) {
type NoMethod EventGadget
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventOrganizer: The organizer of the event. If the organizer is also
// an attendee, this is indicated with a separate entry in attendees
// with the organizer field set to True. To change the organizer, use
// the move operation. Read-only, except when importing an event.
type EventOrganizer struct {
// DisplayName: The organizer's name, if available.
DisplayName string `json:"displayName,omitempty"`
// Email: The organizer's email address, if available. It must be a
// valid email address as per RFC5322.
Email string `json:"email,omitempty"`
// Id: The organizer's Profile ID, if available. It corresponds to the
// id field in the People collection of the Google+ API
Id string `json:"id,omitempty"`
// Self: Whether the organizer corresponds to the calendar on which this
// copy of the event appears. Read-only. The default is False.
Self bool `json:"self,omitempty"`
// ForceSendFields is a list of field names (e.g. "DisplayName") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "DisplayName") to include
// in API requests with the JSON null value. By default, fields with
// empty values are omitted from API requests. However, any field with
// an empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventOrganizer) MarshalJSON() ([]byte, error) {
type NoMethod EventOrganizer
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventReminders: Information about the event's reminders for the
// authenticated user.
type EventReminders struct {
// Overrides: If the event doesn't use the default reminders, this lists
// the reminders specific to the event, or, if not set, indicates that
// no reminders are set for this event. The maximum number of override
// reminders is 5.
Overrides []*EventReminder `json:"overrides,omitempty"`
// UseDefault: Whether the default reminders of the calendar apply to
// the event.
UseDefault bool `json:"useDefault,omitempty"`
// ForceSendFields is a list of field names (e.g. "Overrides") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Overrides") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventReminders) MarshalJSON() ([]byte, error) {
type NoMethod EventReminders
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// EventSource: Source from which the event was created. For example, a
// web page, an email message or any document identifiable by an URL
// with HTTP or HTTPS scheme. Can only be seen or modified by the
// creator of the event.
type EventSource struct {
// Title: Title of the source; for example a title of a web page or an
// email subject.
Title string `json:"title,omitempty"`
// Url: URL of the source pointing to a resource. The URL scheme must be
// HTTP or HTTPS.
Url string `json:"url,omitempty"`
// ForceSendFields is a list of field names (e.g. "Title") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Title") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventSource) MarshalJSON() ([]byte, error) {
type NoMethod EventSource
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type EventAttachment struct {
// FileId: ID of the attached file. Read-only.
// For Google Drive files, this is the ID of the corresponding Files
// resource entry in the Drive API.
FileId string `json:"fileId,omitempty"`
// FileUrl: URL link to the attachment.
// For adding Google Drive file attachments use the same format as in
// alternateLink property of the Files resource in the Drive
// API.
// Required when adding an attachment.
FileUrl string `json:"fileUrl,omitempty"`
// IconLink: URL link to the attachment's icon. Read-only.
IconLink string `json:"iconLink,omitempty"`
// MimeType: Internet media type (MIME type) of the attachment.
MimeType string `json:"mimeType,omitempty"`
// Title: Attachment title.
Title string `json:"title,omitempty"`
// ForceSendFields is a list of field names (e.g. "FileId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "FileId") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventAttachment) MarshalJSON() ([]byte, error) {
type NoMethod EventAttachment
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type EventAttendee struct {
// AdditionalGuests: Number of additional guests. Optional. The default
// is 0.
AdditionalGuests int64 `json:"additionalGuests,omitempty"`
// Comment: The attendee's response comment. Optional.
Comment string `json:"comment,omitempty"`
// DisplayName: The attendee's name, if available. Optional.
DisplayName string `json:"displayName,omitempty"`
// Email: The attendee's email address, if available. This field must be
// present when adding an attendee. It must be a valid email address as
// per RFC5322.
// Required when adding an attendee.
Email string `json:"email,omitempty"`
// Id: The attendee's Profile ID, if available. It corresponds to the id
// field in the People collection of the Google+ API
Id string `json:"id,omitempty"`
// Optional: Whether this is an optional attendee. Optional. The default
// is False.
Optional bool `json:"optional,omitempty"`
// Organizer: Whether the attendee is the organizer of the event.
// Read-only. The default is False.
Organizer bool `json:"organizer,omitempty"`
// Resource: Whether the attendee is a resource. Can only be set when
// the attendee is added to the event for the first time. Subsequent
// modifications are ignored. Optional. The default is False.
Resource bool `json:"resource,omitempty"`
// ResponseStatus: The attendee's response status. Possible values are:
//
// - "needsAction" - The attendee has not responded to the invitation.
//
// - "declined" - The attendee has declined the invitation.
// - "tentative" - The attendee has tentatively accepted the invitation.
//
// - "accepted" - The attendee has accepted the invitation.
ResponseStatus string `json:"responseStatus,omitempty"`
// Self: Whether this entry represents the calendar on which this copy
// of the event appears. Read-only. The default is False.
Self bool `json:"self,omitempty"`
// ForceSendFields is a list of field names (e.g. "AdditionalGuests") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AdditionalGuests") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *EventAttendee) MarshalJSON() ([]byte, error) {
type NoMethod EventAttendee
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type EventDateTime struct {
// Date: The date, in the format "yyyy-mm-dd", if this is an all-day
// event.
Date string `json:"date,omitempty"`
// DateTime: The time, as a combined date-time value (formatted
// according to RFC3339). A time zone offset is required unless a time
// zone is explicitly specified in timeZone.
DateTime string `json:"dateTime,omitempty"`
// TimeZone: The time zone in which the time is specified. (Formatted as
// an IANA Time Zone Database name, e.g. "Europe/Zurich".) For recurring
// events this field is required and specifies the time zone in which
// the recurrence is expanded. For single events this field is optional
// and indicates a custom time zone for the event start/end.
TimeZone string `json:"timeZone,omitempty"`
// ForceSendFields is a list of field names (e.g. "Date") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Date") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventDateTime) MarshalJSON() ([]byte, error) {
type NoMethod EventDateTime
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type EventReminder struct {
// Method: The method used by this reminder. Possible values are:
// - "email" - Reminders are sent via email.
// - "sms" - Deprecated. Once this feature is shutdown, the API will no
// longer return reminders using this method. Any newly added SMS
// reminders will be ignored. See Google Calendar SMS notifications to
// be removed for more information.
// Reminders are sent via SMS. These are only available for G Suite
// customers. Requests to set SMS reminders for other account types are
// ignored.
// - "popup" - Reminders are sent via a UI popup.
// Required when adding a reminder.
Method string `json:"method,omitempty"`
// Minutes: Number of minutes before the start of the event when the
// reminder should trigger. Valid values are between 0 and 40320 (4
// weeks in minutes).
// Required when adding a reminder.
Minutes int64 `json:"minutes,omitempty"`
// ForceSendFields is a list of field names (e.g. "Method") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Method") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *EventReminder) MarshalJSON() ([]byte, error) {
type NoMethod EventReminder
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Events struct {
// AccessRole: The user's access role for this calendar. Read-only.
// Possible values are:
// - "none" - The user has no access.
// - "freeBusyReader" - The user has read access to free/busy
// information.
// - "reader" - The user has read access to the calendar. Private events
// will appear to users with reader access, but event details will be
// hidden.
// - "writer" - The user has read and write access to the calendar.
// Private events will appear to users with writer access, and event
// details will be visible.
// - "owner" - The user has ownership of the calendar. This role has all
// of the permissions of the writer role with the additional ability to
// see and manipulate ACLs.
AccessRole string `json:"accessRole,omitempty"`
// DefaultReminders: The default reminders on the calendar for the
// authenticated user. These reminders apply to all events on this
// calendar that do not explicitly override them (i.e. do not have
// reminders.useDefault set to True).
DefaultReminders []*EventReminder `json:"defaultReminders,omitempty"`
// Description: Description of the calendar. Read-only.
Description string `json:"description,omitempty"`
// Etag: ETag of the collection.
Etag string `json:"etag,omitempty"`
// Items: List of events on the calendar.
Items []*Event `json:"items,omitempty"`
// Kind: Type of the collection ("calendar#events").
Kind string `json:"kind,omitempty"`
// NextPageToken: Token used to access the next page of this result.
// Omitted if no further results are available, in which case
// nextSyncToken is provided.
NextPageToken string `json:"nextPageToken,omitempty"`
// NextSyncToken: Token used at a later point in time to retrieve only
// the entries that have changed since this result was returned. Omitted
// if further results are available, in which case nextPageToken is
// provided.
NextSyncToken string `json:"nextSyncToken,omitempty"`
// Summary: Title of the calendar. Read-only.
Summary string `json:"summary,omitempty"`
// TimeZone: The time zone of the calendar. Read-only.
TimeZone string `json:"timeZone,omitempty"`
// Updated: Last modification time of the calendar (as a RFC3339
// timestamp). Read-only.
Updated string `json:"updated,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "AccessRole") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "AccessRole") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Events) MarshalJSON() ([]byte, error) {
type NoMethod Events
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type FreeBusyCalendar struct {
// Busy: List of time ranges during which this calendar should be
// regarded as busy.
Busy []*TimePeriod `json:"busy,omitempty"`
// Errors: Optional error(s) (if computation for the calendar failed).
Errors []*Error `json:"errors,omitempty"`
// ForceSendFields is a list of field names (e.g. "Busy") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Busy") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *FreeBusyCalendar) MarshalJSON() ([]byte, error) {
type NoMethod FreeBusyCalendar
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type FreeBusyGroup struct {
// Calendars: List of calendars' identifiers within a group.
Calendars []string `json:"calendars,omitempty"`
// Errors: Optional error(s) (if computation for the group failed).
Errors []*Error `json:"errors,omitempty"`
// ForceSendFields is a list of field names (e.g. "Calendars") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Calendars") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *FreeBusyGroup) MarshalJSON() ([]byte, error) {
type NoMethod FreeBusyGroup
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type FreeBusyRequest struct {
// CalendarExpansionMax: Maximal number of calendars for which FreeBusy
// information is to be provided. Optional. Maximum value is 50.
CalendarExpansionMax int64 `json:"calendarExpansionMax,omitempty"`
// GroupExpansionMax: Maximal number of calendar identifiers to be
// provided for a single group. Optional. An error is returned for a
// group with more members than this value. Maximum value is 100.
GroupExpansionMax int64 `json:"groupExpansionMax,omitempty"`
// Items: List of calendars and/or groups to query.
Items []*FreeBusyRequestItem `json:"items,omitempty"`
// TimeMax: The end of the interval for the query formatted as per
// RFC3339.
TimeMax string `json:"timeMax,omitempty"`
// TimeMin: The start of the interval for the query formatted as per
// RFC3339.
TimeMin string `json:"timeMin,omitempty"`
// TimeZone: Time zone used in the response. Optional. The default is
// UTC.
TimeZone string `json:"timeZone,omitempty"`
// ForceSendFields is a list of field names (e.g.
// "CalendarExpansionMax") to unconditionally include in API requests.
// By default, fields with empty values are omitted from API requests.
// However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "CalendarExpansionMax") to
// include in API requests with the JSON null value. By default, fields
// with empty values are omitted from API requests. However, any field
// with an empty value appearing in NullFields will be sent to the
// server as null. It is an error if a field in this list has a
// non-empty value. This may be used to include null fields in Patch
// requests.
NullFields []string `json:"-"`
}
func (s *FreeBusyRequest) MarshalJSON() ([]byte, error) {
type NoMethod FreeBusyRequest
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type FreeBusyRequestItem struct {
// Id: The identifier of a calendar or a group.
Id string `json:"id,omitempty"`
// ForceSendFields is a list of field names (e.g. "Id") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Id") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *FreeBusyRequestItem) MarshalJSON() ([]byte, error) {
type NoMethod FreeBusyRequestItem
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type FreeBusyResponse struct {
// Calendars: List of free/busy information for calendars.
Calendars map[string]FreeBusyCalendar `json:"calendars,omitempty"`
// Groups: Expansion of groups.
Groups map[string]FreeBusyGroup `json:"groups,omitempty"`
// Kind: Type of the resource ("calendar#freeBusy").
Kind string `json:"kind,omitempty"`
// TimeMax: The end of the interval.
TimeMax string `json:"timeMax,omitempty"`
// TimeMin: The start of the interval.
TimeMin string `json:"timeMin,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Calendars") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Calendars") to include in
// API requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *FreeBusyResponse) MarshalJSON() ([]byte, error) {
type NoMethod FreeBusyResponse
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Setting struct {
// Etag: ETag of the resource.
Etag string `json:"etag,omitempty"`
// Id: The id of the user setting.
Id string `json:"id,omitempty"`
// Kind: Type of the resource ("calendar#setting").
Kind string `json:"kind,omitempty"`
// Value: Value of the user setting. The format of the value depends on
// the ID of the setting. It must always be a UTF-8 string of length up
// to 1024 characters.
Value string `json:"value,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Etag") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Etag") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Setting) MarshalJSON() ([]byte, error) {
type NoMethod Setting
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type Settings struct {
// Etag: Etag of the collection.
Etag string `json:"etag,omitempty"`
// Items: List of user settings.
Items []*Setting `json:"items,omitempty"`
// Kind: Type of the collection ("calendar#settings").
Kind string `json:"kind,omitempty"`
// NextPageToken: Token used to access the next page of this result.
// Omitted if no further results are available, in which case
// nextSyncToken is provided.
NextPageToken string `json:"nextPageToken,omitempty"`
// NextSyncToken: Token used at a later point in time to retrieve only
// the entries that have changed since this result was returned. Omitted
// if further results are available, in which case nextPageToken is
// provided.
NextSyncToken string `json:"nextSyncToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Etag") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "Etag") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *Settings) MarshalJSON() ([]byte, error) {
type NoMethod Settings
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
type TimePeriod struct {
// End: The (exclusive) end of the time period.
End string `json:"end,omitempty"`
// Start: The (inclusive) start of the time period.
Start string `json:"start,omitempty"`
// ForceSendFields is a list of field names (e.g. "End") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
// NullFields is a list of field names (e.g. "End") to include in API
// requests with the JSON null value. By default, fields with empty
// values are omitted from API requests. However, any field with an
// empty value appearing in NullFields will be sent to the server as
// null. It is an error if a field in this list has a non-empty value.
// This may be used to include null fields in Patch requests.
NullFields []string `json:"-"`
}
func (s *TimePeriod) MarshalJSON() ([]byte, error) {
type NoMethod TimePeriod
raw := NoMethod(*s)
return gensupport.MarshalJSON(raw, s.ForceSendFields, s.NullFields)
}
// method id "calendar.acl.delete":
type AclDeleteCall struct {
s *Service
calendarId string
ruleId string
urlParams_ gensupport.URLParams
ctx_ context.Context
header_ http.Header
}
// Delete: Deletes an access control rule.
func (r *AclService) Delete(calendarId string, ruleId string) *AclDeleteCall {
c := &AclDeleteCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.ruleId = ruleId
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclDeleteCall) Fields(s ...googleapi.Field) *AclDeleteCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclDeleteCall) Context(ctx context.Context) *AclDeleteCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclDeleteCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclDeleteCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
var body io.Reader = nil
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl/{ruleId}")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("DELETE", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
"ruleId": c.ruleId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.delete" call.
func (c *AclDeleteCall) Do(opts ...googleapi.CallOption) error {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if err != nil {
return err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return err
}
return nil
// {
// "description": "Deletes an access control rule.",
// "httpMethod": "DELETE",
// "id": "calendar.acl.delete",
// "parameterOrder": [
// "calendarId",
// "ruleId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "ruleId": {
// "description": "ACL rule identifier.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "calendars/{calendarId}/acl/{ruleId}",
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ]
// }
}
// method id "calendar.acl.get":
type AclGetCall struct {
s *Service
calendarId string
ruleId string
urlParams_ gensupport.URLParams
ifNoneMatch_ string
ctx_ context.Context
header_ http.Header
}
// Get: Returns an access control rule.
func (r *AclService) Get(calendarId string, ruleId string) *AclGetCall {
c := &AclGetCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.ruleId = ruleId
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclGetCall) Fields(s ...googleapi.Field) *AclGetCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *AclGetCall) IfNoneMatch(entityTag string) *AclGetCall {
c.ifNoneMatch_ = entityTag
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclGetCall) Context(ctx context.Context) *AclGetCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclGetCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclGetCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
if c.ifNoneMatch_ != "" {
reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
}
var body io.Reader = nil
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl/{ruleId}")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("GET", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
"ruleId": c.ruleId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.get" call.
// Exactly one of *AclRule or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *AclRule.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *AclGetCall) Do(opts ...googleapi.CallOption) (*AclRule, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &AclRule{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Returns an access control rule.",
// "httpMethod": "GET",
// "id": "calendar.acl.get",
// "parameterOrder": [
// "calendarId",
// "ruleId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "ruleId": {
// "description": "ACL rule identifier.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "calendars/{calendarId}/acl/{ruleId}",
// "response": {
// "$ref": "AclRule"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar",
// "https://www.googleapis.com/auth/calendar.readonly"
// ]
// }
}
// method id "calendar.acl.insert":
type AclInsertCall struct {
s *Service
calendarId string
aclrule *AclRule
urlParams_ gensupport.URLParams
ctx_ context.Context
header_ http.Header
}
// Insert: Creates an access control rule.
func (r *AclService) Insert(calendarId string, aclrule *AclRule) *AclInsertCall {
c := &AclInsertCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.aclrule = aclrule
return c
}
// SendNotifications sets the optional parameter "sendNotifications":
// Whether to send notifications about the calendar sharing change. The
// default is True.
func (c *AclInsertCall) SendNotifications(sendNotifications bool) *AclInsertCall {
c.urlParams_.Set("sendNotifications", fmt.Sprint(sendNotifications))
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclInsertCall) Fields(s ...googleapi.Field) *AclInsertCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclInsertCall) Context(ctx context.Context) *AclInsertCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclInsertCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclInsertCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
var body io.Reader = nil
body, err := googleapi.WithoutDataWrapper.JSONReader(c.aclrule)
if err != nil {
return nil, err
}
reqHeaders.Set("Content-Type", "application/json")
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("POST", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.insert" call.
// Exactly one of *AclRule or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *AclRule.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *AclInsertCall) Do(opts ...googleapi.CallOption) (*AclRule, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &AclRule{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Creates an access control rule.",
// "httpMethod": "POST",
// "id": "calendar.acl.insert",
// "parameterOrder": [
// "calendarId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "sendNotifications": {
// "description": "Whether to send notifications about the calendar sharing change. Optional. The default is True.",
// "location": "query",
// "type": "boolean"
// }
// },
// "path": "calendars/{calendarId}/acl",
// "request": {
// "$ref": "AclRule"
// },
// "response": {
// "$ref": "AclRule"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ]
// }
}
// method id "calendar.acl.list":
type AclListCall struct {
s *Service
calendarId string
urlParams_ gensupport.URLParams
ifNoneMatch_ string
ctx_ context.Context
header_ http.Header
}
// List: Returns the rules in the access control list for the calendar.
func (r *AclService) List(calendarId string) *AclListCall {
c := &AclListCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
return c
}
// MaxResults sets the optional parameter "maxResults": Maximum number
// of entries returned on one result page. By default the value is 100
// entries. The page size can never be larger than 250 entries.
func (c *AclListCall) MaxResults(maxResults int64) *AclListCall {
c.urlParams_.Set("maxResults", fmt.Sprint(maxResults))
return c
}
// PageToken sets the optional parameter "pageToken": Token specifying
// which result page to return.
func (c *AclListCall) PageToken(pageToken string) *AclListCall {
c.urlParams_.Set("pageToken", pageToken)
return c
}
// ShowDeleted sets the optional parameter "showDeleted": Whether to
// include deleted ACLs in the result. Deleted ACLs are represented by
// role equal to "none". Deleted ACLs will always be included if
// syncToken is provided. The default is False.
func (c *AclListCall) ShowDeleted(showDeleted bool) *AclListCall {
c.urlParams_.Set("showDeleted", fmt.Sprint(showDeleted))
return c
}
// SyncToken sets the optional parameter "syncToken": Token obtained
// from the nextSyncToken field returned on the last page of results
// from the previous list request. It makes the result of this list
// request contain only entries that have changed since then. All
// entries deleted since the previous list request will always be in the
// result set and it is not allowed to set showDeleted to False.
// If the syncToken expires, the server will respond with a 410 GONE
// response code and the client should clear its storage and perform a
// full synchronization without any syncToken.
// Learn more about incremental synchronization.
// The default is to return all entries.
func (c *AclListCall) SyncToken(syncToken string) *AclListCall {
c.urlParams_.Set("syncToken", syncToken)
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclListCall) Fields(s ...googleapi.Field) *AclListCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *AclListCall) IfNoneMatch(entityTag string) *AclListCall {
c.ifNoneMatch_ = entityTag
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclListCall) Context(ctx context.Context) *AclListCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclListCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclListCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
if c.ifNoneMatch_ != "" {
reqHeaders.Set("If-None-Match", c.ifNoneMatch_)
}
var body io.Reader = nil
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("GET", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.list" call.
// Exactly one of *Acl or error will be non-nil. Any non-2xx status code
// is an error. Response headers are in either
// *Acl.ServerResponse.Header or (if a response was returned at all) in
// error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check
// whether the returned error was because http.StatusNotModified was
// returned.
func (c *AclListCall) Do(opts ...googleapi.CallOption) (*Acl, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Acl{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Returns the rules in the access control list for the calendar.",
// "httpMethod": "GET",
// "id": "calendar.acl.list",
// "parameterOrder": [
// "calendarId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "maxResults": {
// "description": "Maximum number of entries returned on one result page. By default the value is 100 entries. The page size can never be larger than 250 entries. Optional.",
// "format": "int32",
// "location": "query",
// "minimum": "1",
// "type": "integer"
// },
// "pageToken": {
// "description": "Token specifying which result page to return. Optional.",
// "location": "query",
// "type": "string"
// },
// "showDeleted": {
// "description": "Whether to include deleted ACLs in the result. Deleted ACLs are represented by role equal to \"none\". Deleted ACLs will always be included if syncToken is provided. Optional. The default is False.",
// "location": "query",
// "type": "boolean"
// },
// "syncToken": {
// "description": "Token obtained from the nextSyncToken field returned on the last page of results from the previous list request. It makes the result of this list request contain only entries that have changed since then. All entries deleted since the previous list request will always be in the result set and it is not allowed to set showDeleted to False.\nIf the syncToken expires, the server will respond with a 410 GONE response code and the client should clear its storage and perform a full synchronization without any syncToken.\nLearn more about incremental synchronization.\nOptional. The default is to return all entries.",
// "location": "query",
// "type": "string"
// }
// },
// "path": "calendars/{calendarId}/acl",
// "response": {
// "$ref": "Acl"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ],
// "supportsSubscription": true
// }
}
// Pages invokes f for each page of results.
// A non-nil error returned from f will halt the iteration.
// The provided context supersedes any context provided to the Context method.
func (c *AclListCall) Pages(ctx context.Context, f func(*Acl) error) error {
c.ctx_ = ctx
defer c.PageToken(c.urlParams_.Get("pageToken")) // reset paging to original point
for {
x, err := c.Do()
if err != nil {
return err
}
if err := f(x); err != nil {
return err
}
if x.NextPageToken == "" {
return nil
}
c.PageToken(x.NextPageToken)
}
}
// method id "calendar.acl.patch":
type AclPatchCall struct {
s *Service
calendarId string
ruleId string
aclrule *AclRule
urlParams_ gensupport.URLParams
ctx_ context.Context
header_ http.Header
}
// Patch: Updates an access control rule. This method supports patch
// semantics.
func (r *AclService) Patch(calendarId string, ruleId string, aclrule *AclRule) *AclPatchCall {
c := &AclPatchCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.ruleId = ruleId
c.aclrule = aclrule
return c
}
// SendNotifications sets the optional parameter "sendNotifications":
// Whether to send notifications about the calendar sharing change. Note
// that there are no notifications on access removal. The default is
// True.
func (c *AclPatchCall) SendNotifications(sendNotifications bool) *AclPatchCall {
c.urlParams_.Set("sendNotifications", fmt.Sprint(sendNotifications))
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclPatchCall) Fields(s ...googleapi.Field) *AclPatchCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclPatchCall) Context(ctx context.Context) *AclPatchCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclPatchCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclPatchCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
var body io.Reader = nil
body, err := googleapi.WithoutDataWrapper.JSONReader(c.aclrule)
if err != nil {
return nil, err
}
reqHeaders.Set("Content-Type", "application/json")
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl/{ruleId}")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("PATCH", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
"ruleId": c.ruleId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.patch" call.
// Exactly one of *AclRule or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *AclRule.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *AclPatchCall) Do(opts ...googleapi.CallOption) (*AclRule, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &AclRule{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Updates an access control rule. This method supports patch semantics.",
// "httpMethod": "PATCH",
// "id": "calendar.acl.patch",
// "parameterOrder": [
// "calendarId",
// "ruleId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "ruleId": {
// "description": "ACL rule identifier.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "sendNotifications": {
// "description": "Whether to send notifications about the calendar sharing change. Note that there are no notifications on access removal. Optional. The default is True.",
// "location": "query",
// "type": "boolean"
// }
// },
// "path": "calendars/{calendarId}/acl/{ruleId}",
// "request": {
// "$ref": "AclRule"
// },
// "response": {
// "$ref": "AclRule"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ]
// }
}
// method id "calendar.acl.update":
type AclUpdateCall struct {
s *Service
calendarId string
ruleId string
aclrule *AclRule
urlParams_ gensupport.URLParams
ctx_ context.Context
header_ http.Header
}
// Update: Updates an access control rule.
func (r *AclService) Update(calendarId string, ruleId string, aclrule *AclRule) *AclUpdateCall {
c := &AclUpdateCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.ruleId = ruleId
c.aclrule = aclrule
return c
}
// SendNotifications sets the optional parameter "sendNotifications":
// Whether to send notifications about the calendar sharing change. Note
// that there are no notifications on access removal. The default is
// True.
func (c *AclUpdateCall) SendNotifications(sendNotifications bool) *AclUpdateCall {
c.urlParams_.Set("sendNotifications", fmt.Sprint(sendNotifications))
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclUpdateCall) Fields(s ...googleapi.Field) *AclUpdateCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclUpdateCall) Context(ctx context.Context) *AclUpdateCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclUpdateCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclUpdateCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
var body io.Reader = nil
body, err := googleapi.WithoutDataWrapper.JSONReader(c.aclrule)
if err != nil {
return nil, err
}
reqHeaders.Set("Content-Type", "application/json")
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl/{ruleId}")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("PUT", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
"ruleId": c.ruleId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.update" call.
// Exactly one of *AclRule or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *AclRule.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *AclUpdateCall) Do(opts ...googleapi.CallOption) (*AclRule, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &AclRule{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Updates an access control rule.",
// "httpMethod": "PUT",
// "id": "calendar.acl.update",
// "parameterOrder": [
// "calendarId",
// "ruleId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "ruleId": {
// "description": "ACL rule identifier.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "sendNotifications": {
// "description": "Whether to send notifications about the calendar sharing change. Note that there are no notifications on access removal. Optional. The default is True.",
// "location": "query",
// "type": "boolean"
// }
// },
// "path": "calendars/{calendarId}/acl/{ruleId}",
// "request": {
// "$ref": "AclRule"
// },
// "response": {
// "$ref": "AclRule"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ]
// }
}
// method id "calendar.acl.watch":
type AclWatchCall struct {
s *Service
calendarId string
channel *Channel
urlParams_ gensupport.URLParams
ctx_ context.Context
header_ http.Header
}
// Watch: Watch for changes to ACL resources.
func (r *AclService) Watch(calendarId string, channel *Channel) *AclWatchCall {
c := &AclWatchCall{s: r.s, urlParams_: make(gensupport.URLParams)}
c.calendarId = calendarId
c.channel = channel
return c
}
// MaxResults sets the optional parameter "maxResults": Maximum number
// of entries returned on one result page. By default the value is 100
// entries. The page size can never be larger than 250 entries.
func (c *AclWatchCall) MaxResults(maxResults int64) *AclWatchCall {
c.urlParams_.Set("maxResults", fmt.Sprint(maxResults))
return c
}
// PageToken sets the optional parameter "pageToken": Token specifying
// which result page to return.
func (c *AclWatchCall) PageToken(pageToken string) *AclWatchCall {
c.urlParams_.Set("pageToken", pageToken)
return c
}
// ShowDeleted sets the optional parameter "showDeleted": Whether to
// include deleted ACLs in the result. Deleted ACLs are represented by
// role equal to "none". Deleted ACLs will always be included if
// syncToken is provided. The default is False.
func (c *AclWatchCall) ShowDeleted(showDeleted bool) *AclWatchCall {
c.urlParams_.Set("showDeleted", fmt.Sprint(showDeleted))
return c
}
// SyncToken sets the optional parameter "syncToken": Token obtained
// from the nextSyncToken field returned on the last page of results
// from the previous list request. It makes the result of this list
// request contain only entries that have changed since then. All
// entries deleted since the previous list request will always be in the
// result set and it is not allowed to set showDeleted to False.
// If the syncToken expires, the server will respond with a 410 GONE
// response code and the client should clear its storage and perform a
// full synchronization without any syncToken.
// Learn more about incremental synchronization.
// The default is to return all entries.
func (c *AclWatchCall) SyncToken(syncToken string) *AclWatchCall {
c.urlParams_.Set("syncToken", syncToken)
return c
}
// Fields allows partial responses to be retrieved. See
// https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AclWatchCall) Fields(s ...googleapi.Field) *AclWatchCall {
c.urlParams_.Set("fields", googleapi.CombineFields(s))
return c
}
// Context sets the context to be used in this call's Do method. Any
// pending HTTP request will be aborted if the provided context is
// canceled.
func (c *AclWatchCall) Context(ctx context.Context) *AclWatchCall {
c.ctx_ = ctx
return c
}
// Header returns an http.Header that can be modified by the caller to
// add HTTP headers to the request.
func (c *AclWatchCall) Header() http.Header {
if c.header_ == nil {
c.header_ = make(http.Header)
}
return c.header_
}
func (c *AclWatchCall) doRequest(alt string) (*http.Response, error) {
reqHeaders := make(http.Header)
for k, v := range c.header_ {
reqHeaders[k] = v
}
reqHeaders.Set("User-Agent", c.s.userAgent())
var body io.Reader = nil
body, err := googleapi.WithoutDataWrapper.JSONReader(c.channel)
if err != nil {
return nil, err
}
reqHeaders.Set("Content-Type", "application/json")
c.urlParams_.Set("alt", alt)
c.urlParams_.Set("prettyPrint", "false")
urls := googleapi.ResolveRelative(c.s.BasePath, "calendars/{calendarId}/acl/watch")
urls += "?" + c.urlParams_.Encode()
req, err := http.NewRequest("POST", urls, body)
if err != nil {
return nil, err
}
req.Header = reqHeaders
googleapi.Expand(req.URL, map[string]string{
"calendarId": c.calendarId,
})
return gensupport.SendRequest(c.ctx_, c.s.client, req)
}
// Do executes the "calendar.acl.watch" call.
// Exactly one of *Channel or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Channel.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *AclWatchCall) Do(opts ...googleapi.CallOption) (*Channel, error) {
gensupport.SetOptions(c.urlParams_, opts...)
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Channel{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
target := &ret
if err := gensupport.DecodeResponse(target, res); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Watch for changes to ACL resources.",
// "httpMethod": "POST",
// "id": "calendar.acl.watch",
// "parameterOrder": [
// "calendarId"
// ],
// "parameters": {
// "calendarId": {
// "description": "Calendar identifier. To retrieve calendar IDs call the calendarList.list method. If you want to access the primary calendar of the currently logged in user, use the \"primary\" keyword.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "maxResults": {
// "description": "Maximum number of entries returned on one result page. By default the value is 100 entries. The page size can never be larger than 250 entries. Optional.",
// "format": "int32",
// "location": "query",
// "minimum": "1",
// "type": "integer"
// },
// "pageToken": {
// "description": "Token specifying which result page to return. Optional.",
// "location": "query",
// "type": "string"
// },
// "showDeleted": {
// "description": "Whether to include deleted ACLs in the result. Deleted ACLs are represented by role equal to \"none\". Deleted ACLs will always be included if syncToken is provided. Optional. The default is False.",
// "location": "query",
// "type": "boolean"
// },
// "syncToken": {
// "description": "Token obtained from the nextSyncToken field returned on the last page of results from the previous list request. It makes the result of this list request contain only entries that have changed since then. All entries deleted since the previous list request will always be in the result set and it is not allowed to set showDeleted to False.\nIf the syncToken expires, the server will respond with a 410 GONE response code and the client should clear its storage and perform a full synchronization without any syncToken.\nLearn more about incremental synchronization.\nOptional. The default is to return all entries.",
// "location": "query",
// "type": "string"
// }
// },
// "path": "calendars/{calendarId}/acl/watch",
// "request": {
// "$ref": "Channel",
// "parameterName": "resource"
// },
// "response": {
// "$ref": "Channel"
// },
// "scopes": [
// "https://www.googleapis.com/auth/calendar"
// ],
// "supportsSubscription": true
// }
}
// method id "calendar.calendarList.delete":
type CalendarListDeleteCall struct {
s *Service
calendarId string
urlParams_ gensupport.URLParams
ctx_ context.Context