| // This is a generated file (see the discoveryapis_generator project). |
| |
| // ignore_for_file: unused_import, unnecessary_cast |
| |
| library googleapis.people.v1; |
| |
| import 'dart:core' as core; |
| import 'dart:async' as async; |
| import 'dart:convert' as convert; |
| |
| import 'package:_discoveryapis_commons/_discoveryapis_commons.dart' as commons; |
| import 'package:http/http.dart' as http; |
| |
| export 'package:_discoveryapis_commons/_discoveryapis_commons.dart' |
| show ApiRequestError, DetailedApiRequestError; |
| |
| const core.String USER_AGENT = 'dart-api-client people/v1'; |
| |
| /// Provides access to information about profiles and contacts. |
| class PeopleApi { |
| /// See, edit, download, and permanently delete your contacts |
| static const ContactsScope = "https://www.googleapis.com/auth/contacts"; |
| |
| /// See and download contact info automatically saved in your "Other contacts" |
| static const ContactsOtherReadonlyScope = |
| "https://www.googleapis.com/auth/contacts.other.readonly"; |
| |
| /// See and download your contacts |
| static const ContactsReadonlyScope = |
| "https://www.googleapis.com/auth/contacts.readonly"; |
| |
| /// See and download your organization's GSuite directory |
| static const DirectoryReadonlyScope = |
| "https://www.googleapis.com/auth/directory.readonly"; |
| |
| /// View your street addresses |
| static const UserAddressesReadScope = |
| "https://www.googleapis.com/auth/user.addresses.read"; |
| |
| /// View your complete date of birth |
| static const UserBirthdayReadScope = |
| "https://www.googleapis.com/auth/user.birthday.read"; |
| |
| /// View your email addresses |
| static const UserEmailsReadScope = |
| "https://www.googleapis.com/auth/user.emails.read"; |
| |
| /// See your gender |
| static const UserGenderReadScope = |
| "https://www.googleapis.com/auth/user.gender.read"; |
| |
| /// See your education, work history and org info |
| static const UserOrganizationReadScope = |
| "https://www.googleapis.com/auth/user.organization.read"; |
| |
| /// View your phone numbers |
| static const UserPhonenumbersReadScope = |
| "https://www.googleapis.com/auth/user.phonenumbers.read"; |
| |
| /// View your email address |
| static const UserinfoEmailScope = |
| "https://www.googleapis.com/auth/userinfo.email"; |
| |
| /// See your personal info, including any personal info you've made publicly |
| /// available |
| static const UserinfoProfileScope = |
| "https://www.googleapis.com/auth/userinfo.profile"; |
| |
| final commons.ApiRequester _requester; |
| |
| ContactGroupsResourceApi get contactGroups => |
| new ContactGroupsResourceApi(_requester); |
| OtherContactsResourceApi get otherContacts => |
| new OtherContactsResourceApi(_requester); |
| PeopleResourceApi get people => new PeopleResourceApi(_requester); |
| |
| PeopleApi(http.Client client, |
| {core.String rootUrl = "https://people.googleapis.com/", |
| core.String servicePath = ""}) |
| : _requester = |
| new commons.ApiRequester(client, rootUrl, servicePath, USER_AGENT); |
| } |
| |
| class ContactGroupsResourceApi { |
| final commons.ApiRequester _requester; |
| |
| ContactGroupsMembersResourceApi get members => |
| new ContactGroupsMembersResourceApi(_requester); |
| |
| ContactGroupsResourceApi(commons.ApiRequester client) : _requester = client; |
| |
| /// Get a list of contact groups owned by the authenticated user by specifying |
| /// a list of contact group resource names. |
| /// |
| /// Request parameters: |
| /// |
| /// [maxMembers] - Optional. Specifies the maximum number of members to return |
| /// for each group. Defaults to 0 if not set, which will return zero members. |
| /// |
| /// [resourceNames] - Required. The resource names of the contact groups to |
| /// get. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [BatchGetContactGroupsResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<BatchGetContactGroupsResponse> batchGet( |
| {core.int maxMembers, |
| core.List<core.String> resourceNames, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (maxMembers != null) { |
| _queryParams["maxMembers"] = ["${maxMembers}"]; |
| } |
| if (resourceNames != null) { |
| _queryParams["resourceNames"] = resourceNames; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/contactGroups:batchGet'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new BatchGetContactGroupsResponse.fromJson(data)); |
| } |
| |
| /// Create a new contact group owned by the authenticated user. |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ContactGroup]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ContactGroup> create(CreateContactGroupRequest request, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/contactGroups'; |
| |
| var _response = _requester.request(_url, "POST", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new ContactGroup.fromJson(data)); |
| } |
| |
| /// Delete an existing contact group owned by the authenticated user by |
| /// specifying a contact group resource name. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the contact group to |
| /// delete. |
| /// Value must have pattern "^contactGroups/[^/]+$". |
| /// |
| /// [deleteContacts] - Optional. Set to true to also delete the contacts in |
| /// the specified group. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Empty]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Empty> delete(core.String resourceName, |
| {core.bool deleteContacts, core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (deleteContacts != null) { |
| _queryParams["deleteContacts"] = ["${deleteContacts}"]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + commons.Escaper.ecapeVariableReserved('$resourceName'); |
| |
| var _response = _requester.request(_url, "DELETE", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Empty.fromJson(data)); |
| } |
| |
| /// Get a specific contact group owned by the authenticated user by specifying |
| /// a contact group resource name. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the contact group to get. |
| /// Value must have pattern "^contactGroups/[^/]+$". |
| /// |
| /// [maxMembers] - Optional. Specifies the maximum number of members to |
| /// return. Defaults to 0 if not set, which will return zero members. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ContactGroup]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ContactGroup> get(core.String resourceName, |
| {core.int maxMembers, core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (maxMembers != null) { |
| _queryParams["maxMembers"] = ["${maxMembers}"]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + commons.Escaper.ecapeVariableReserved('$resourceName'); |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new ContactGroup.fromJson(data)); |
| } |
| |
| /// List all contact groups owned by the authenticated user. Members of the |
| /// contact groups are not populated. |
| /// |
| /// Request parameters: |
| /// |
| /// [pageSize] - Optional. The maximum number of resources to return. Valid |
| /// values are between 1 and 1000, inclusive. Defaults to 30 if not set or set |
| /// to 0. |
| /// |
| /// [pageToken] - Optional. The next_page_token value returned from a previous |
| /// call to [ListContactGroups](/people/api/rest/v1/contactgroups/list). |
| /// Requests the next page of resources. |
| /// |
| /// [syncToken] - Optional. A sync token, returned by a previous call to |
| /// `contactgroups.list`. Only resources changed since the sync token was |
| /// created will be returned. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ListContactGroupsResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ListContactGroupsResponse> list( |
| {core.int pageSize, |
| core.String pageToken, |
| core.String syncToken, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (pageSize != null) { |
| _queryParams["pageSize"] = ["${pageSize}"]; |
| } |
| if (pageToken != null) { |
| _queryParams["pageToken"] = [pageToken]; |
| } |
| if (syncToken != null) { |
| _queryParams["syncToken"] = [syncToken]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/contactGroups'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new ListContactGroupsResponse.fromJson(data)); |
| } |
| |
| /// Update the name of an existing contact group owned by the authenticated |
| /// user. |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - The resource name for the contact group, assigned by the |
| /// server. An ASCII string, in the form of |
| /// `contactGroups/{contact_group_id}`. |
| /// Value must have pattern "^contactGroups/[^/]+$". |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ContactGroup]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ContactGroup> update( |
| UpdateContactGroupRequest request, core.String resourceName, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + commons.Escaper.ecapeVariableReserved('$resourceName'); |
| |
| var _response = _requester.request(_url, "PUT", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new ContactGroup.fromJson(data)); |
| } |
| } |
| |
| class ContactGroupsMembersResourceApi { |
| final commons.ApiRequester _requester; |
| |
| ContactGroupsMembersResourceApi(commons.ApiRequester client) |
| : _requester = client; |
| |
| /// Modify the members of a contact group owned by the authenticated user. The |
| /// only system contact groups that can have members added are |
| /// `contactGroups/myContacts` and `contactGroups/starred`. Other system |
| /// contact groups are deprecated and can only have contacts removed. |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the contact group to |
| /// modify. |
| /// Value must have pattern "^contactGroups/[^/]+$". |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ModifyContactGroupMembersResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ModifyContactGroupMembersResponse> modify( |
| ModifyContactGroupMembersRequest request, core.String resourceName, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| '/members:modify'; |
| |
| var _response = _requester.request(_url, "POST", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new ModifyContactGroupMembersResponse.fromJson(data)); |
| } |
| } |
| |
| class OtherContactsResourceApi { |
| final commons.ApiRequester _requester; |
| |
| OtherContactsResourceApi(commons.ApiRequester client) : _requester = client; |
| |
| /// Copies an "Other contact" to a new contact in the user's "myContacts" |
| /// group |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the "Other contact" to |
| /// copy. |
| /// Value must have pattern "^otherContacts/[^/]+$". |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Person]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Person> copyOtherContactToMyContactsGroup( |
| CopyOtherContactToMyContactsGroupRequest request, |
| core.String resourceName, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| ':copyOtherContactToMyContactsGroup'; |
| |
| var _response = _requester.request(_url, "POST", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Person.fromJson(data)); |
| } |
| |
| /// List all "Other contacts", that is contacts that are not in a contact |
| /// group. "Other contacts" are typically auto created contacts from |
| /// interactions. |
| /// |
| /// Request parameters: |
| /// |
| /// [requestSyncToken] - Optional. Whether the response should include |
| /// `next_sync_token`, which can be used to get all changes since the last |
| /// request. For subsequent sync requests use the `sync_token` param instead. |
| /// Initial sync requests that specify `request_sync_token` have an additional |
| /// rate limit. |
| /// |
| /// [pageToken] - Optional. A page token, received from a previous |
| /// `ListOtherContacts` call. Provide this to retrieve the subsequent page. |
| /// When paginating, all other parameters provided to `ListOtherContacts` must |
| /// match the call that provided the page token. |
| /// |
| /// [readMask] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * emailAddresses * names * phoneNumbers |
| /// |
| /// [pageSize] - Optional. The number of "Other contacts" to include in the |
| /// response. Valid values are between 1 and 1000, inclusive. Defaults to 100 |
| /// if not set or set to 0. |
| /// |
| /// [syncToken] - Optional. A sync token, received from a previous |
| /// `ListOtherContacts` call. Provide this to retrieve only the resources |
| /// changed since the last request. Sync requests that specify `sync_token` |
| /// have an additional rate limit. When syncing, all other parameters provided |
| /// to `ListOtherContacts` must match the call that provided the sync token. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ListOtherContactsResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ListOtherContactsResponse> list( |
| {core.bool requestSyncToken, |
| core.String pageToken, |
| core.String readMask, |
| core.int pageSize, |
| core.String syncToken, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (requestSyncToken != null) { |
| _queryParams["requestSyncToken"] = ["${requestSyncToken}"]; |
| } |
| if (pageToken != null) { |
| _queryParams["pageToken"] = [pageToken]; |
| } |
| if (readMask != null) { |
| _queryParams["readMask"] = [readMask]; |
| } |
| if (pageSize != null) { |
| _queryParams["pageSize"] = ["${pageSize}"]; |
| } |
| if (syncToken != null) { |
| _queryParams["syncToken"] = [syncToken]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/otherContacts'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new ListOtherContactsResponse.fromJson(data)); |
| } |
| } |
| |
| class PeopleResourceApi { |
| final commons.ApiRequester _requester; |
| |
| PeopleConnectionsResourceApi get connections => |
| new PeopleConnectionsResourceApi(_requester); |
| |
| PeopleResourceApi(commons.ApiRequester client) : _requester = client; |
| |
| /// Create a new contact and return the person resource for that contact. The |
| /// request throws a 400 error if more than one field is specified on a field |
| /// that is a singleton for contact sources: * biographies * birthdays * |
| /// genders * names |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [personFields] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Defaults to all fields if not set. Valid values are: * |
| /// addresses * ageRanges * biographies * birthdays * calendarUrls * |
| /// clientData * coverPhotos * emailAddresses * events * externalIds * genders |
| /// * imClients * interests * locales * locations * memberships * metadata * |
| /// miscKeywords * names * nicknames * occupations * organizations * |
| /// phoneNumbers * photos * relations * sipAddresses * skills * urls * |
| /// userDefined |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Person]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Person> createContact(Person request, |
| {core.String personFields, |
| core.List<core.String> sources, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/people:createContact'; |
| |
| var _response = _requester.request(_url, "POST", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Person.fromJson(data)); |
| } |
| |
| /// Delete a contact person. Any non-contact data will not be deleted. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the contact to delete. |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Empty]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Empty> deleteContact(core.String resourceName, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| ':deleteContact'; |
| |
| var _response = _requester.request(_url, "DELETE", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Empty.fromJson(data)); |
| } |
| |
| /// Delete a contact's photo. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the contact whose photo |
| /// will be deleted. |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| /// |
| /// [personFields] - Optional. A field mask to restrict which fields on the |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Defaults to empty if not set, which will skip the post mutate |
| /// get. Valid values are: * addresses * ageRanges * biographies * birthdays * |
| /// calendarUrls * clientData * coverPhotos * emailAddresses * events * |
| /// externalIds * genders * imClients * interests * locales * locations * |
| /// memberships * metadata * miscKeywords * names * nicknames * occupations * |
| /// organizations * phoneNumbers * photos * relations * sipAddresses * skills |
| /// * urls * userDefined |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [DeleteContactPhotoResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<DeleteContactPhotoResponse> deleteContactPhoto( |
| core.String resourceName, |
| {core.List<core.String> sources, |
| core.String personFields, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| ':deleteContactPhoto'; |
| |
| var _response = _requester.request(_url, "DELETE", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new DeleteContactPhotoResponse.fromJson(data)); |
| } |
| |
| /// Provides information about a person by specifying a resource name. Use |
| /// `people/me` to indicate the authenticated user. The request throws a 400 |
| /// error if 'personFields' is not specified. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name of the person to provide |
| /// information about. - To get information about the authenticated user, |
| /// specify `people/me`. - To get information about a google account, specify |
| /// `people/{account_id}`. - To get information about a contact, specify the |
| /// resource name that identifies the contact as returned by |
| /// [`people.connections.list`](/people/api/rest/v1/people.connections/list). |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.PROFILE and ReadSourceType.CONTACT if not set. |
| /// |
| /// [requestMask_includeField] - Required. Comma-separated list of person |
| /// fields to be included in the response. Each path should start with |
| /// `person.`: for example, `person.names` or `person.photos`. |
| /// |
| /// [personFields] - Required. A field mask to restrict which fields on the |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * addresses * ageRanges * biographies * |
| /// birthdays * calendarUrls * clientData * coverPhotos * emailAddresses * |
| /// events * externalIds * genders * imClients * interests * locales * |
| /// locations * memberships * metadata * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * photos * relations * |
| /// sipAddresses * skills * urls * userDefined |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Person]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Person> get(core.String resourceName, |
| {core.List<core.String> sources, |
| core.String requestMask_includeField, |
| core.String personFields, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (requestMask_includeField != null) { |
| _queryParams["requestMask.includeField"] = [requestMask_includeField]; |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + commons.Escaper.ecapeVariableReserved('$resourceName'); |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Person.fromJson(data)); |
| } |
| |
| /// Provides information about a list of specific people by specifying a list |
| /// of requested resource names. Use `people/me` to indicate the authenticated |
| /// user. The request throws a 400 error if 'personFields' is not specified. |
| /// |
| /// Request parameters: |
| /// |
| /// [requestMask_includeField] - Required. Comma-separated list of person |
| /// fields to be included in the response. Each path should start with |
| /// `person.`: for example, `person.names` or `person.photos`. |
| /// |
| /// [personFields] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * addresses * ageRanges * biographies * |
| /// birthdays * calendarUrls * clientData * coverPhotos * emailAddresses * |
| /// events * externalIds * genders * imClients * interests * locales * |
| /// locations * memberships * metadata * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * photos * relations * |
| /// sipAddresses * skills * urls * userDefined |
| /// |
| /// [resourceNames] - Required. The resource names of the people to provide |
| /// information about. It's repeatable. The URL query parameter should be |
| /// resourceNames=<name1>&resourceNames=<name2>&... - To get information about |
| /// the authenticated user, specify `people/me`. - To get information about a |
| /// google account, specify `people/{account_id}`. - To get information about |
| /// a contact, specify the resource name that identifies the contact as |
| /// returned by |
| /// [`people.connections.list`](/people/api/rest/v1/people.connections/list). |
| /// You can include up to 50 resource names in one request. |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [GetPeopleResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<GetPeopleResponse> getBatchGet( |
| {core.String requestMask_includeField, |
| core.String personFields, |
| core.List<core.String> resourceNames, |
| core.List<core.String> sources, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (requestMask_includeField != null) { |
| _queryParams["requestMask.includeField"] = [requestMask_includeField]; |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if (resourceNames != null) { |
| _queryParams["resourceNames"] = resourceNames; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/people:batchGet'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new GetPeopleResponse.fromJson(data)); |
| } |
| |
| /// Provides a list of domain profiles and domain contacts in the |
| /// authenticated user's domain directory. |
| /// |
| /// Request parameters: |
| /// |
| /// [syncToken] - Optional. A sync token, received from a previous |
| /// `ListDirectoryPeople` call. Provide this to retrieve only the resources |
| /// changed since the last request. When syncing, all other parameters |
| /// provided to `ListDirectoryPeople` must match the call that provided the |
| /// sync token. |
| /// |
| /// [mergeSources] - Optional. Additional data to merge into the directory |
| /// sources if they are connected through verified join keys such as email |
| /// addresses or phone numbers. |
| /// |
| /// [pageToken] - Optional. A page token, received from a previous |
| /// `ListDirectoryPeople` call. Provide this to retrieve the subsequent page. |
| /// When paginating, all other parameters provided to `ListDirectoryPeople` |
| /// must match the call that provided the page token. |
| /// |
| /// [requestSyncToken] - Optional. Whether the response should include |
| /// `next_sync_token`, which can be used to get all changes since the last |
| /// request. For subsequent sync requests use the `sync_token` param instead. |
| /// |
| /// [sources] - Required. Directory sources to return. |
| /// |
| /// [readMask] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * addresses * ageRanges * biographies * |
| /// birthdays * calendarUrls * clientData * coverPhotos * emailAddresses * |
| /// events * externalIds * genders * imClients * interests * locales * |
| /// locations * memberships * metadata * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * photos * relations * |
| /// sipAddresses * skills * urls * userDefined |
| /// |
| /// [pageSize] - Optional. The number of people to include in the response. |
| /// Valid values are between 1 and 1000, inclusive. Defaults to 100 if not set |
| /// or set to 0. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ListDirectoryPeopleResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ListDirectoryPeopleResponse> listDirectoryPeople( |
| {core.String syncToken, |
| core.List<core.String> mergeSources, |
| core.String pageToken, |
| core.bool requestSyncToken, |
| core.List<core.String> sources, |
| core.String readMask, |
| core.int pageSize, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (syncToken != null) { |
| _queryParams["syncToken"] = [syncToken]; |
| } |
| if (mergeSources != null) { |
| _queryParams["mergeSources"] = mergeSources; |
| } |
| if (pageToken != null) { |
| _queryParams["pageToken"] = [pageToken]; |
| } |
| if (requestSyncToken != null) { |
| _queryParams["requestSyncToken"] = ["${requestSyncToken}"]; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (readMask != null) { |
| _queryParams["readMask"] = [readMask]; |
| } |
| if (pageSize != null) { |
| _queryParams["pageSize"] = ["${pageSize}"]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/people:listDirectoryPeople'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new ListDirectoryPeopleResponse.fromJson(data)); |
| } |
| |
| /// Provides a list of domain profiles and domain contacts in the |
| /// authenticated user's domain directory that match the search query. |
| /// |
| /// Request parameters: |
| /// |
| /// [mergeSources] - Optional. Additional data to merge into the directory |
| /// sources if they are connected through verified join keys such as email |
| /// addresses or phone numbers. |
| /// |
| /// [sources] - Required. Directory sources to return. |
| /// |
| /// [query] - Required. Prefix query that matches fields in the person. Does |
| /// NOT use the read_mask for determining what fields to match. |
| /// |
| /// [pageToken] - Optional. A page token, received from a previous |
| /// `SearchDirectoryPeople` call. Provide this to retrieve the subsequent |
| /// page. When paginating, all other parameters provided to |
| /// `SearchDirectoryPeople` must match the call that provided the page token. |
| /// |
| /// [readMask] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * addresses * ageRanges * biographies * |
| /// birthdays * calendarUrls * clientData * coverPhotos * emailAddresses * |
| /// events * externalIds * genders * imClients * interests * locales * |
| /// locations * memberships * metadata * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * photos * relations * |
| /// sipAddresses * skills * urls * userDefined |
| /// |
| /// [pageSize] - Optional. The number of people to include in the response. |
| /// Valid values are between 1 and 500, inclusive. Defaults to 100 if not set |
| /// or set to 0. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [SearchDirectoryPeopleResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<SearchDirectoryPeopleResponse> searchDirectoryPeople( |
| {core.List<core.String> mergeSources, |
| core.List<core.String> sources, |
| core.String query, |
| core.String pageToken, |
| core.String readMask, |
| core.int pageSize, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (mergeSources != null) { |
| _queryParams["mergeSources"] = mergeSources; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (query != null) { |
| _queryParams["query"] = [query]; |
| } |
| if (pageToken != null) { |
| _queryParams["pageToken"] = [pageToken]; |
| } |
| if (readMask != null) { |
| _queryParams["readMask"] = [readMask]; |
| } |
| if (pageSize != null) { |
| _queryParams["pageSize"] = ["${pageSize}"]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/people:searchDirectoryPeople'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new SearchDirectoryPeopleResponse.fromJson(data)); |
| } |
| |
| /// Update contact data for an existing contact person. Any non-contact data |
| /// will not be modified. Any non-contact data in the person to update will be |
| /// ignored. All fields specified in the `update_mask` will be replaced. The |
| /// server returns a 400 error if `person.metadata.sources` is not specified |
| /// for the contact to be updated or if there is no contact source. The server |
| /// returns a 400 error with reason `"failedPrecondition"` if |
| /// `person.metadata.sources.etag` is different than the contact's etag, which |
| /// indicates the contact has changed since its data was read. Clients should |
| /// get the latest person and merge their updates into the latest person. The |
| /// server returns a 400 error if `memberships` are being updated and there |
| /// are no contact group memberships specified on the person. The server |
| /// returns a 400 error if more than one field is specified on a field that is |
| /// a singleton for contact sources: * biographies * birthdays * genders * |
| /// names |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - The resource name for the person, assigned by the server. |
| /// An ASCII string with a max length of 27 characters, in the form of |
| /// `people/{person_id}`. |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [updatePersonFields] - Required. A field mask to restrict which fields on |
| /// the person are updated. Multiple fields can be specified by separating |
| /// them with commas. All updated fields will be replaced. Valid values are: * |
| /// addresses * biographies * birthdays * calendarUrls * clientData * |
| /// emailAddresses * events * externalIds * genders * imClients * interests * |
| /// locales * locations * memberships * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * relations * sipAddresses * |
| /// urls * userDefined |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| /// |
| /// [personFields] - Optional. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Defaults to all fields if not set. Valid values are: * |
| /// addresses * ageRanges * biographies * birthdays * calendarUrls * |
| /// clientData * coverPhotos * emailAddresses * events * externalIds * genders |
| /// * imClients * interests * locales * locations * memberships * metadata * |
| /// miscKeywords * names * nicknames * occupations * organizations * |
| /// phoneNumbers * photos * relations * sipAddresses * skills * urls * |
| /// userDefined |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [Person]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<Person> updateContact(Person request, core.String resourceName, |
| {core.String updatePersonFields, |
| core.List<core.String> sources, |
| core.String personFields, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (updatePersonFields != null) { |
| _queryParams["updatePersonFields"] = [updatePersonFields]; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| ':updateContact'; |
| |
| var _response = _requester.request(_url, "PATCH", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new Person.fromJson(data)); |
| } |
| |
| /// Update a contact's photo. |
| /// |
| /// [request] - The metadata request object. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. Person resource name |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [UpdateContactPhotoResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<UpdateContactPhotoResponse> updateContactPhoto( |
| UpdateContactPhotoRequest request, core.String resourceName, |
| {core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (request != null) { |
| _body = convert.json.encode((request).toJson()); |
| } |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| ':updateContactPhoto'; |
| |
| var _response = _requester.request(_url, "PATCH", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response |
| .then((data) => new UpdateContactPhotoResponse.fromJson(data)); |
| } |
| } |
| |
| class PeopleConnectionsResourceApi { |
| final commons.ApiRequester _requester; |
| |
| PeopleConnectionsResourceApi(commons.ApiRequester client) |
| : _requester = client; |
| |
| /// Provides a list of the authenticated user's contacts. The request throws a |
| /// 400 error if 'personFields' is not specified. |
| /// |
| /// Request parameters: |
| /// |
| /// [resourceName] - Required. The resource name to return connections for. |
| /// Only `people/me` is valid. |
| /// Value must have pattern "^people/[^/]+$". |
| /// |
| /// [sortOrder] - Optional. The order in which the connections should be |
| /// sorted. Defaults to `LAST_MODIFIED_ASCENDING`. |
| /// Possible string values are: |
| /// - "LAST_MODIFIED_ASCENDING" : Sort people by when they were changed; older |
| /// entries first. |
| /// - "LAST_MODIFIED_DESCENDING" : Sort people by when they were changed; |
| /// newer entries first. |
| /// - "FIRST_NAME_ASCENDING" : Sort people by first name. |
| /// - "LAST_NAME_ASCENDING" : Sort people by last name. |
| /// |
| /// [requestSyncToken] - Optional. Whether the response should include |
| /// `next_sync_token` on the last page, which can be used to get all changes |
| /// since the last request. For subsequent sync requests use the `sync_token` |
| /// param instead. Initial sync requests that specify `request_sync_token` |
| /// have an additional rate limit. |
| /// |
| /// [pageSize] - Optional. The number of connections to include in the |
| /// response. Valid values are between 1 and 1000, inclusive. Defaults to 100 |
| /// if not set or set to 0. |
| /// |
| /// [sources] - Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| /// |
| /// [requestMask_includeField] - Required. Comma-separated list of person |
| /// fields to be included in the response. Each path should start with |
| /// `person.`: for example, `person.names` or `person.photos`. |
| /// |
| /// [pageToken] - Optional. A page token, received from a previous |
| /// `ListConnections` call. Provide this to retrieve the subsequent page. When |
| /// paginating, all other parameters provided to `ListConnections` must match |
| /// the call that provided the page token. |
| /// |
| /// [personFields] - Required. A field mask to restrict which fields on each |
| /// person are returned. Multiple fields can be specified by separating them |
| /// with commas. Valid values are: * addresses * ageRanges * biographies * |
| /// birthdays * calendarUrls * clientData * coverPhotos * emailAddresses * |
| /// events * externalIds * genders * imClients * interests * locales * |
| /// locations * memberships * metadata * miscKeywords * names * nicknames * |
| /// occupations * organizations * phoneNumbers * photos * relations * |
| /// sipAddresses * skills * urls * userDefined |
| /// |
| /// [syncToken] - Optional. A sync token, received from a previous |
| /// `ListConnections` call. Provide this to retrieve only the resources |
| /// changed since the last request. Sync requests that specify `sync_token` |
| /// have an additional rate limit. When syncing, all other parameters provided |
| /// to `ListConnections` must match the call that provided the sync token. |
| /// |
| /// [$fields] - Selector specifying which fields to include in a partial |
| /// response. |
| /// |
| /// Completes with a [ListConnectionsResponse]. |
| /// |
| /// Completes with a [commons.ApiRequestError] if the API endpoint returned an |
| /// error. |
| /// |
| /// If the used [http.Client] completes with an error when making a REST call, |
| /// this method will complete with the same error. |
| async.Future<ListConnectionsResponse> list(core.String resourceName, |
| {core.String sortOrder, |
| core.bool requestSyncToken, |
| core.int pageSize, |
| core.List<core.String> sources, |
| core.String requestMask_includeField, |
| core.String pageToken, |
| core.String personFields, |
| core.String syncToken, |
| core.String $fields}) { |
| var _url; |
| var _queryParams = new core.Map<core.String, core.List<core.String>>(); |
| var _uploadMedia; |
| var _uploadOptions; |
| var _downloadOptions = commons.DownloadOptions.Metadata; |
| var _body; |
| |
| if (resourceName == null) { |
| throw new core.ArgumentError("Parameter resourceName is required."); |
| } |
| if (sortOrder != null) { |
| _queryParams["sortOrder"] = [sortOrder]; |
| } |
| if (requestSyncToken != null) { |
| _queryParams["requestSyncToken"] = ["${requestSyncToken}"]; |
| } |
| if (pageSize != null) { |
| _queryParams["pageSize"] = ["${pageSize}"]; |
| } |
| if (sources != null) { |
| _queryParams["sources"] = sources; |
| } |
| if (requestMask_includeField != null) { |
| _queryParams["requestMask.includeField"] = [requestMask_includeField]; |
| } |
| if (pageToken != null) { |
| _queryParams["pageToken"] = [pageToken]; |
| } |
| if (personFields != null) { |
| _queryParams["personFields"] = [personFields]; |
| } |
| if (syncToken != null) { |
| _queryParams["syncToken"] = [syncToken]; |
| } |
| if ($fields != null) { |
| _queryParams["fields"] = [$fields]; |
| } |
| |
| _url = 'v1/' + |
| commons.Escaper.ecapeVariableReserved('$resourceName') + |
| '/connections'; |
| |
| var _response = _requester.request(_url, "GET", |
| body: _body, |
| queryParams: _queryParams, |
| uploadOptions: _uploadOptions, |
| uploadMedia: _uploadMedia, |
| downloadOptions: _downloadOptions); |
| return _response.then((data) => new ListConnectionsResponse.fromJson(data)); |
| } |
| } |
| |
| /// A person's physical address. May be a P.O. box or street address. All fields |
| /// are optional. |
| class Address { |
| /// The city of the address. |
| core.String city; |
| |
| /// The country of the address. |
| core.String country; |
| |
| /// The [ISO 3166-1 alpha-2](http://www.iso.org/iso/country_codes.htm) country |
| /// code of the address. |
| core.String countryCode; |
| |
| /// The extended address of the address; for example, the apartment number. |
| core.String extendedAddress; |
| |
| /// Output only. The type of the address translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// The unstructured value of the address. If this is not set by the user it |
| /// will be automatically constructed from structured values. |
| core.String formattedValue; |
| |
| /// Metadata about the address. |
| FieldMetadata metadata; |
| |
| /// The P.O. box of the address. |
| core.String poBox; |
| |
| /// The postal code of the address. |
| core.String postalCode; |
| |
| /// The region of the address; for example, the state or province. |
| core.String region; |
| |
| /// The street address. |
| core.String streetAddress; |
| |
| /// The type of the address. The type can be custom or one of these predefined |
| /// values: * `home` * `work` * `other` |
| core.String type; |
| |
| Address(); |
| |
| Address.fromJson(core.Map _json) { |
| if (_json.containsKey("city")) { |
| city = _json["city"]; |
| } |
| if (_json.containsKey("country")) { |
| country = _json["country"]; |
| } |
| if (_json.containsKey("countryCode")) { |
| countryCode = _json["countryCode"]; |
| } |
| if (_json.containsKey("extendedAddress")) { |
| extendedAddress = _json["extendedAddress"]; |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("formattedValue")) { |
| formattedValue = _json["formattedValue"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("poBox")) { |
| poBox = _json["poBox"]; |
| } |
| if (_json.containsKey("postalCode")) { |
| postalCode = _json["postalCode"]; |
| } |
| if (_json.containsKey("region")) { |
| region = _json["region"]; |
| } |
| if (_json.containsKey("streetAddress")) { |
| streetAddress = _json["streetAddress"]; |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (city != null) { |
| _json["city"] = city; |
| } |
| if (country != null) { |
| _json["country"] = country; |
| } |
| if (countryCode != null) { |
| _json["countryCode"] = countryCode; |
| } |
| if (extendedAddress != null) { |
| _json["extendedAddress"] = extendedAddress; |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (formattedValue != null) { |
| _json["formattedValue"] = formattedValue; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (poBox != null) { |
| _json["poBox"] = poBox; |
| } |
| if (postalCode != null) { |
| _json["postalCode"] = postalCode; |
| } |
| if (region != null) { |
| _json["region"] = region; |
| } |
| if (streetAddress != null) { |
| _json["streetAddress"] = streetAddress; |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's age range. |
| class AgeRangeType { |
| /// The age range. |
| /// Possible string values are: |
| /// - "AGE_RANGE_UNSPECIFIED" : Unspecified. |
| /// - "LESS_THAN_EIGHTEEN" : Younger than eighteen. |
| /// - "EIGHTEEN_TO_TWENTY" : Between eighteen and twenty. |
| /// - "TWENTY_ONE_OR_OLDER" : Twenty-one and older. |
| core.String ageRange; |
| |
| /// Metadata about the age range. |
| FieldMetadata metadata; |
| |
| AgeRangeType(); |
| |
| AgeRangeType.fromJson(core.Map _json) { |
| if (_json.containsKey("ageRange")) { |
| ageRange = _json["ageRange"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (ageRange != null) { |
| _json["ageRange"] = ageRange; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a batch get contact groups request. |
| class BatchGetContactGroupsResponse { |
| /// The list of responses for each requested contact group resource. |
| core.List<ContactGroupResponse> responses; |
| |
| BatchGetContactGroupsResponse(); |
| |
| BatchGetContactGroupsResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("responses")) { |
| responses = (_json["responses"] as core.List) |
| .map<ContactGroupResponse>( |
| (value) => new ContactGroupResponse.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (responses != null) { |
| _json["responses"] = responses.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's short biography. |
| class Biography { |
| /// The content type of the biography. |
| /// Possible string values are: |
| /// - "CONTENT_TYPE_UNSPECIFIED" : Unspecified. |
| /// - "TEXT_PLAIN" : Plain text. |
| /// - "TEXT_HTML" : HTML text. |
| core.String contentType; |
| |
| /// Metadata about the biography. |
| FieldMetadata metadata; |
| |
| /// The short biography. |
| core.String value; |
| |
| Biography(); |
| |
| Biography.fromJson(core.Map _json) { |
| if (_json.containsKey("contentType")) { |
| contentType = _json["contentType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contentType != null) { |
| _json["contentType"] = contentType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's birthday. At least one of the `date` and `text` fields are |
| /// specified. The `date` and `text` fields typically represent the same date, |
| /// but are not guaranteed to. |
| class Birthday { |
| /// The date of the birthday. |
| Date date; |
| |
| /// Metadata about the birthday. |
| FieldMetadata metadata; |
| |
| /// A free-form string representing the user's birthday. |
| core.String text; |
| |
| Birthday(); |
| |
| Birthday.fromJson(core.Map _json) { |
| if (_json.containsKey("date")) { |
| date = new Date.fromJson(_json["date"]); |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("text")) { |
| text = _json["text"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (date != null) { |
| _json["date"] = (date).toJson(); |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (text != null) { |
| _json["text"] = text; |
| } |
| return _json; |
| } |
| } |
| |
| /// **DEPRECATED**: No data will be returned A person's bragging rights. |
| class BraggingRights { |
| /// Metadata about the bragging rights. |
| FieldMetadata metadata; |
| |
| /// The bragging rights; for example, `climbed mount everest`. |
| core.String value; |
| |
| BraggingRights(); |
| |
| BraggingRights.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's calendar URL. |
| class CalendarUrl { |
| /// Output only. The type of the calendar URL translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the calendar URL. |
| FieldMetadata metadata; |
| |
| /// The type of the calendar URL. The type can be custom or one of these |
| /// predefined values: * `home` * `freeBusy` * `work` |
| core.String type; |
| |
| /// The calendar URL. |
| core.String url; |
| |
| CalendarUrl(); |
| |
| CalendarUrl.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("url")) { |
| url = _json["url"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (url != null) { |
| _json["url"] = url; |
| } |
| return _json; |
| } |
| } |
| |
| /// Arbitrary client data that is populated by clients. Duplicate keys and |
| /// values are allowed. |
| class ClientData { |
| /// The client specified key of the client data. |
| core.String key; |
| |
| /// Metadata about the client data. |
| FieldMetadata metadata; |
| |
| /// The client specified value of the client data. |
| core.String value; |
| |
| ClientData(); |
| |
| ClientData.fromJson(core.Map _json) { |
| if (_json.containsKey("key")) { |
| key = _json["key"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (key != null) { |
| _json["key"] = key; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A contact group. |
| class ContactGroup { |
| /// The [HTTP entity tag](https://en.wikipedia.org/wiki/HTTP_ETag) of the |
| /// resource. Used for web cache validation. |
| core.String etag; |
| |
| /// Output only. The name translated and formatted in the viewer's account |
| /// locale or the `Accept-Language` HTTP header locale for system groups |
| /// names. Group names set by the owner are the same as name. |
| core.String formattedName; |
| |
| /// Output only. The contact group type. |
| /// Possible string values are: |
| /// - "GROUP_TYPE_UNSPECIFIED" : Unspecified. |
| /// - "USER_CONTACT_GROUP" : User defined contact group. |
| /// - "SYSTEM_CONTACT_GROUP" : System defined contact group. |
| core.String groupType; |
| |
| /// Output only. The total number of contacts in the group irrespective of max |
| /// members in specified in the request. |
| core.int memberCount; |
| |
| /// Output only. The list of contact person resource names that are members of |
| /// the contact group. The field is not populated for LIST requests and can |
| /// only be updated through the |
| /// [ModifyContactGroupMembers](/people/api/rest/v1/contactgroups/members/modify). |
| core.List<core.String> memberResourceNames; |
| |
| /// Output only. Metadata about the contact group. |
| ContactGroupMetadata metadata; |
| |
| /// The contact group name set by the group owner or a system provided name |
| /// for system groups. |
| core.String name; |
| |
| /// The resource name for the contact group, assigned by the server. An ASCII |
| /// string, in the form of `contactGroups/{contact_group_id}`. |
| core.String resourceName; |
| |
| ContactGroup(); |
| |
| ContactGroup.fromJson(core.Map _json) { |
| if (_json.containsKey("etag")) { |
| etag = _json["etag"]; |
| } |
| if (_json.containsKey("formattedName")) { |
| formattedName = _json["formattedName"]; |
| } |
| if (_json.containsKey("groupType")) { |
| groupType = _json["groupType"]; |
| } |
| if (_json.containsKey("memberCount")) { |
| memberCount = _json["memberCount"]; |
| } |
| if (_json.containsKey("memberResourceNames")) { |
| memberResourceNames = |
| (_json["memberResourceNames"] as core.List).cast<core.String>(); |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new ContactGroupMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("name")) { |
| name = _json["name"]; |
| } |
| if (_json.containsKey("resourceName")) { |
| resourceName = _json["resourceName"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (etag != null) { |
| _json["etag"] = etag; |
| } |
| if (formattedName != null) { |
| _json["formattedName"] = formattedName; |
| } |
| if (groupType != null) { |
| _json["groupType"] = groupType; |
| } |
| if (memberCount != null) { |
| _json["memberCount"] = memberCount; |
| } |
| if (memberResourceNames != null) { |
| _json["memberResourceNames"] = memberResourceNames; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (name != null) { |
| _json["name"] = name; |
| } |
| if (resourceName != null) { |
| _json["resourceName"] = resourceName; |
| } |
| return _json; |
| } |
| } |
| |
| /// A Google contact group membership. |
| class ContactGroupMembership { |
| /// Output only. The contact group ID for the contact group membership. |
| core.String contactGroupId; |
| |
| /// The resource name for the contact group, assigned by the server. An ASCII |
| /// string, in the form of `contactGroups/{contact_group_id}`. Only |
| /// contact_group_resource_name can be used for modifying memberships. Any |
| /// contact group membership can be removed, but only user group or |
| /// "myContacts" or "starred" system groups memberships can be added. A |
| /// contact must always have at least one contact group membership. |
| core.String contactGroupResourceName; |
| |
| ContactGroupMembership(); |
| |
| ContactGroupMembership.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroupId")) { |
| contactGroupId = _json["contactGroupId"]; |
| } |
| if (_json.containsKey("contactGroupResourceName")) { |
| contactGroupResourceName = _json["contactGroupResourceName"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroupId != null) { |
| _json["contactGroupId"] = contactGroupId; |
| } |
| if (contactGroupResourceName != null) { |
| _json["contactGroupResourceName"] = contactGroupResourceName; |
| } |
| return _json; |
| } |
| } |
| |
| /// The metadata about a contact group. |
| class ContactGroupMetadata { |
| /// Output only. True if the contact group resource has been deleted. |
| /// Populated only for |
| /// [`ListContactGroups`](/people/api/rest/v1/contactgroups/list) requests |
| /// that include a sync token. |
| core.bool deleted; |
| |
| /// Output only. The time the group was last updated. |
| core.String updateTime; |
| |
| ContactGroupMetadata(); |
| |
| ContactGroupMetadata.fromJson(core.Map _json) { |
| if (_json.containsKey("deleted")) { |
| deleted = _json["deleted"]; |
| } |
| if (_json.containsKey("updateTime")) { |
| updateTime = _json["updateTime"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (deleted != null) { |
| _json["deleted"] = deleted; |
| } |
| if (updateTime != null) { |
| _json["updateTime"] = updateTime; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response for a specific contact group. |
| class ContactGroupResponse { |
| /// The contact group. |
| ContactGroup contactGroup; |
| |
| /// The original requested resource name. |
| core.String requestedResourceName; |
| |
| /// The status of the response. |
| Status status; |
| |
| ContactGroupResponse(); |
| |
| ContactGroupResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroup")) { |
| contactGroup = new ContactGroup.fromJson(_json["contactGroup"]); |
| } |
| if (_json.containsKey("requestedResourceName")) { |
| requestedResourceName = _json["requestedResourceName"]; |
| } |
| if (_json.containsKey("status")) { |
| status = new Status.fromJson(_json["status"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroup != null) { |
| _json["contactGroup"] = (contactGroup).toJson(); |
| } |
| if (requestedResourceName != null) { |
| _json["requestedResourceName"] = requestedResourceName; |
| } |
| if (status != null) { |
| _json["status"] = (status).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A request to copy an "Other contact" to my contacts group. |
| class CopyOtherContactToMyContactsGroupRequest { |
| /// Required. A field mask to restrict which fields are copied into the new |
| /// contact. Valid values are: * emailAddresses * names * phoneNumbers |
| core.String copyMask; |
| |
| /// Optional. A field mask to restrict which fields on the person are |
| /// returned. Multiple fields can be specified by separating them with commas. |
| /// Defaults to the copy mask with metadata and membership fields if not set. |
| /// Valid values are: * addresses * ageRanges * biographies * birthdays * |
| /// calendarUrls * clientData * coverPhotos * emailAddresses * events * |
| /// externalIds * genders * imClients * interests * locales * locations * |
| /// memberships * metadata * miscKeywords * names * nicknames * occupations * |
| /// organizations * phoneNumbers * photos * relations * sipAddresses * skills |
| /// * urls * userDefined |
| core.String readMask; |
| |
| /// Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| core.List<core.String> sources; |
| |
| CopyOtherContactToMyContactsGroupRequest(); |
| |
| CopyOtherContactToMyContactsGroupRequest.fromJson(core.Map _json) { |
| if (_json.containsKey("copyMask")) { |
| copyMask = _json["copyMask"]; |
| } |
| if (_json.containsKey("readMask")) { |
| readMask = _json["readMask"]; |
| } |
| if (_json.containsKey("sources")) { |
| sources = (_json["sources"] as core.List).cast<core.String>(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (copyMask != null) { |
| _json["copyMask"] = copyMask; |
| } |
| if (readMask != null) { |
| _json["readMask"] = readMask; |
| } |
| if (sources != null) { |
| _json["sources"] = sources; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's cover photo. A large image shown on the person's profile page |
| /// that represents who they are or what they care about. |
| class CoverPhoto { |
| /// True if the cover photo is the default cover photo; false if the cover |
| /// photo is a user-provided cover photo. |
| core.bool default_; |
| |
| /// Metadata about the cover photo. |
| FieldMetadata metadata; |
| |
| /// The URL of the cover photo. |
| core.String url; |
| |
| CoverPhoto(); |
| |
| CoverPhoto.fromJson(core.Map _json) { |
| if (_json.containsKey("default")) { |
| default_ = _json["default"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("url")) { |
| url = _json["url"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (default_ != null) { |
| _json["default"] = default_; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (url != null) { |
| _json["url"] = url; |
| } |
| return _json; |
| } |
| } |
| |
| /// A request to create a new contact group. |
| class CreateContactGroupRequest { |
| /// Required. The contact group to create. |
| ContactGroup contactGroup; |
| |
| CreateContactGroupRequest(); |
| |
| CreateContactGroupRequest.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroup")) { |
| contactGroup = new ContactGroup.fromJson(_json["contactGroup"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroup != null) { |
| _json["contactGroup"] = (contactGroup).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// Represents a whole or partial calendar date, e.g. a birthday. The time of |
| /// day and time zone are either specified elsewhere or are not significant. The |
| /// date is relative to the Proleptic Gregorian Calendar. This can represent: * |
| /// A full date, with non-zero year, month and day values * A month and day |
| /// value, with a zero year, e.g. an anniversary * A year on its own, with zero |
| /// month and day values * A year and month value, with a zero day, e.g. a |
| /// credit card expiration date Related types are google.type.TimeOfDay and |
| /// `google.protobuf.Timestamp`. |
| class Date { |
| /// Day of month. Must be from 1 to 31 and valid for the year and month, or 0 |
| /// if specifying a year by itself or a year and month where the day is not |
| /// significant. |
| core.int day; |
| |
| /// Month of year. Must be from 1 to 12, or 0 if specifying a year without a |
| /// month and day. |
| core.int month; |
| |
| /// Year of date. Must be from 1 to 9999, or 0 if specifying a date without a |
| /// year. |
| core.int year; |
| |
| Date(); |
| |
| Date.fromJson(core.Map _json) { |
| if (_json.containsKey("day")) { |
| day = _json["day"]; |
| } |
| if (_json.containsKey("month")) { |
| month = _json["month"]; |
| } |
| if (_json.containsKey("year")) { |
| year = _json["year"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (day != null) { |
| _json["day"] = day; |
| } |
| if (month != null) { |
| _json["month"] = month; |
| } |
| if (year != null) { |
| _json["year"] = year; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response for deleteing a contact's photo. |
| class DeleteContactPhotoResponse { |
| /// The updated person, if person_fields is set in the |
| /// DeleteContactPhotoRequest; otherwise this will be unset. |
| Person person; |
| |
| DeleteContactPhotoResponse(); |
| |
| DeleteContactPhotoResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("person")) { |
| person = new Person.fromJson(_json["person"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (person != null) { |
| _json["person"] = (person).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A G Suite Domain membership. |
| class DomainMembership { |
| /// True if the person is in the viewer's G Suite domain. |
| core.bool inViewerDomain; |
| |
| DomainMembership(); |
| |
| DomainMembership.fromJson(core.Map _json) { |
| if (_json.containsKey("inViewerDomain")) { |
| inViewerDomain = _json["inViewerDomain"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (inViewerDomain != null) { |
| _json["inViewerDomain"] = inViewerDomain; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's email address. |
| class EmailAddress { |
| /// The display name of the email. |
| core.String displayName; |
| |
| /// Output only. The type of the email address translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the email address. |
| FieldMetadata metadata; |
| |
| /// The type of the email address. The type can be custom or one of these |
| /// predefined values: * `home` * `work` * `other` |
| core.String type; |
| |
| /// The email address. |
| core.String value; |
| |
| EmailAddress(); |
| |
| EmailAddress.fromJson(core.Map _json) { |
| if (_json.containsKey("displayName")) { |
| displayName = _json["displayName"]; |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (displayName != null) { |
| _json["displayName"] = displayName; |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A generic empty message that you can re-use to avoid defining duplicated |
| /// empty messages in your APIs. A typical example is to use it as the request |
| /// or the response type of an API method. For instance: service Foo { rpc |
| /// Bar(google.protobuf.Empty) returns (google.protobuf.Empty); } The JSON |
| /// representation for `Empty` is empty JSON object `{}`. |
| class Empty { |
| Empty(); |
| |
| Empty.fromJson(core.Map _json) {} |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| return _json; |
| } |
| } |
| |
| /// An event related to the person. |
| class Event { |
| /// The date of the event. |
| Date date; |
| |
| /// Output only. The type of the event translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the event. |
| FieldMetadata metadata; |
| |
| /// The type of the event. The type can be custom or one of these predefined |
| /// values: * `anniversary` * `other` |
| core.String type; |
| |
| Event(); |
| |
| Event.fromJson(core.Map _json) { |
| if (_json.containsKey("date")) { |
| date = new Date.fromJson(_json["date"]); |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (date != null) { |
| _json["date"] = (date).toJson(); |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| return _json; |
| } |
| } |
| |
| /// An identifier from an external entity related to the person. |
| class ExternalId { |
| /// Output only. The type of the event translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the external ID. |
| FieldMetadata metadata; |
| |
| /// The type of the external ID. The type can be custom or one of these |
| /// predefined values: * `account` * `customer` * `loginId` * `network` * |
| /// `organization` |
| core.String type; |
| |
| /// The value of the external ID. |
| core.String value; |
| |
| ExternalId(); |
| |
| ExternalId.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// Metadata about a field. |
| class FieldMetadata { |
| /// True if the field is the primary field; false if the field is a secondary |
| /// field. |
| core.bool primary; |
| |
| /// The source of the field. |
| Source source; |
| |
| /// Output only. True if the field is verified; false if the field is |
| /// unverified. A verified field is typically a name, email address, phone |
| /// number, or website that has been confirmed to be owned by the person. |
| core.bool verified; |
| |
| FieldMetadata(); |
| |
| FieldMetadata.fromJson(core.Map _json) { |
| if (_json.containsKey("primary")) { |
| primary = _json["primary"]; |
| } |
| if (_json.containsKey("source")) { |
| source = new Source.fromJson(_json["source"]); |
| } |
| if (_json.containsKey("verified")) { |
| verified = _json["verified"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (primary != null) { |
| _json["primary"] = primary; |
| } |
| if (source != null) { |
| _json["source"] = (source).toJson(); |
| } |
| if (verified != null) { |
| _json["verified"] = verified; |
| } |
| return _json; |
| } |
| } |
| |
| /// The name that should be used to sort the person in a list. |
| class FileAs { |
| /// Metadata about the file-as. |
| FieldMetadata metadata; |
| |
| /// The file-as value |
| core.String value; |
| |
| FileAs(); |
| |
| FileAs.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's gender. |
| class Gender { |
| /// The type of pronouns that should be used to address the person. The value |
| /// can be custom or one of these predefined values: * `male` * `female` * |
| /// `other` |
| core.String addressMeAs; |
| |
| /// Output only. The value of the gender translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| /// Unspecified or custom value are not localized. |
| core.String formattedValue; |
| |
| /// Metadata about the gender. |
| FieldMetadata metadata; |
| |
| /// The gender for the person. The gender can be custom or one of these |
| /// predefined values: * `male` * `female` * `unspecified` |
| core.String value; |
| |
| Gender(); |
| |
| Gender.fromJson(core.Map _json) { |
| if (_json.containsKey("addressMeAs")) { |
| addressMeAs = _json["addressMeAs"]; |
| } |
| if (_json.containsKey("formattedValue")) { |
| formattedValue = _json["formattedValue"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (addressMeAs != null) { |
| _json["addressMeAs"] = addressMeAs; |
| } |
| if (formattedValue != null) { |
| _json["formattedValue"] = formattedValue; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a get request for a list of people by resource name. |
| class GetPeopleResponse { |
| /// The response for each requested resource name. |
| core.List<PersonResponse> responses; |
| |
| GetPeopleResponse(); |
| |
| GetPeopleResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("responses")) { |
| responses = (_json["responses"] as core.List) |
| .map<PersonResponse>((value) => new PersonResponse.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (responses != null) { |
| _json["responses"] = responses.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's instant messaging client. |
| class ImClient { |
| /// Output only. The protocol of the IM client formatted in the viewer's |
| /// account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedProtocol; |
| |
| /// Output only. The type of the IM client translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the IM client. |
| FieldMetadata metadata; |
| |
| /// The protocol of the IM client. The protocol can be custom or one of these |
| /// predefined values: * `aim` * `msn` * `yahoo` * `skype` * `qq` * |
| /// `googleTalk` * `icq` * `jabber` * `netMeeting` |
| core.String protocol; |
| |
| /// The type of the IM client. The type can be custom or one of these |
| /// predefined values: * `home` * `work` * `other` |
| core.String type; |
| |
| /// The user name used in the IM client. |
| core.String username; |
| |
| ImClient(); |
| |
| ImClient.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedProtocol")) { |
| formattedProtocol = _json["formattedProtocol"]; |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("protocol")) { |
| protocol = _json["protocol"]; |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("username")) { |
| username = _json["username"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedProtocol != null) { |
| _json["formattedProtocol"] = formattedProtocol; |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (protocol != null) { |
| _json["protocol"] = protocol; |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (username != null) { |
| _json["username"] = username; |
| } |
| return _json; |
| } |
| } |
| |
| /// One of the person's interests. |
| class Interest { |
| /// Metadata about the interest. |
| FieldMetadata metadata; |
| |
| /// The interest; for example, `stargazing`. |
| core.String value; |
| |
| Interest(); |
| |
| Interest.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a request for the authenticated user's connections. |
| class ListConnectionsResponse { |
| /// The list of people that the requestor is connected to. |
| core.List<Person> connections; |
| |
| /// A token, which can be sent as `page_token` to retrieve the next page. If |
| /// this field is omitted, there are no subsequent pages. |
| core.String nextPageToken; |
| |
| /// A token, which can be sent as `sync_token` to retrieve changes since the |
| /// last request. Request must set `request_sync_token` to return the sync |
| /// token. When the response is paginated, only the last page will contain |
| /// `nextSyncToken`. |
| core.String nextSyncToken; |
| |
| /// The total number of items in the list without pagination. |
| core.int totalItems; |
| |
| /// **DEPRECATED** (Please use totalItems) The total number of people in the |
| /// list without pagination. |
| core.int totalPeople; |
| |
| ListConnectionsResponse(); |
| |
| ListConnectionsResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("connections")) { |
| connections = (_json["connections"] as core.List) |
| .map<Person>((value) => new Person.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("nextPageToken")) { |
| nextPageToken = _json["nextPageToken"]; |
| } |
| if (_json.containsKey("nextSyncToken")) { |
| nextSyncToken = _json["nextSyncToken"]; |
| } |
| if (_json.containsKey("totalItems")) { |
| totalItems = _json["totalItems"]; |
| } |
| if (_json.containsKey("totalPeople")) { |
| totalPeople = _json["totalPeople"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (connections != null) { |
| _json["connections"] = |
| connections.map((value) => (value).toJson()).toList(); |
| } |
| if (nextPageToken != null) { |
| _json["nextPageToken"] = nextPageToken; |
| } |
| if (nextSyncToken != null) { |
| _json["nextSyncToken"] = nextSyncToken; |
| } |
| if (totalItems != null) { |
| _json["totalItems"] = totalItems; |
| } |
| if (totalPeople != null) { |
| _json["totalPeople"] = totalPeople; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a list contact groups request. |
| class ListContactGroupsResponse { |
| /// The list of contact groups. Members of the contact groups are not |
| /// populated. |
| core.List<ContactGroup> contactGroups; |
| |
| /// The token that can be used to retrieve the next page of results. |
| core.String nextPageToken; |
| |
| /// The token that can be used to retrieve changes since the last request. |
| core.String nextSyncToken; |
| |
| /// The total number of items in the list without pagination. |
| core.int totalItems; |
| |
| ListContactGroupsResponse(); |
| |
| ListContactGroupsResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroups")) { |
| contactGroups = (_json["contactGroups"] as core.List) |
| .map<ContactGroup>((value) => new ContactGroup.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("nextPageToken")) { |
| nextPageToken = _json["nextPageToken"]; |
| } |
| if (_json.containsKey("nextSyncToken")) { |
| nextSyncToken = _json["nextSyncToken"]; |
| } |
| if (_json.containsKey("totalItems")) { |
| totalItems = _json["totalItems"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroups != null) { |
| _json["contactGroups"] = |
| contactGroups.map((value) => (value).toJson()).toList(); |
| } |
| if (nextPageToken != null) { |
| _json["nextPageToken"] = nextPageToken; |
| } |
| if (nextSyncToken != null) { |
| _json["nextSyncToken"] = nextSyncToken; |
| } |
| if (totalItems != null) { |
| _json["totalItems"] = totalItems; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a request for the authenticated user's domain directory. |
| class ListDirectoryPeopleResponse { |
| /// A token, which can be sent as `page_token` to retrieve the next page. If |
| /// this field is omitted, there are no subsequent pages. |
| core.String nextPageToken; |
| |
| /// A token, which can be sent as `sync_token` to retrieve changes since the |
| /// last request. Request must set `request_sync_token` to return the sync |
| /// token. |
| core.String nextSyncToken; |
| |
| /// The list of people in the domain directory. |
| core.List<Person> people; |
| |
| ListDirectoryPeopleResponse(); |
| |
| ListDirectoryPeopleResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("nextPageToken")) { |
| nextPageToken = _json["nextPageToken"]; |
| } |
| if (_json.containsKey("nextSyncToken")) { |
| nextSyncToken = _json["nextSyncToken"]; |
| } |
| if (_json.containsKey("people")) { |
| people = (_json["people"] as core.List) |
| .map<Person>((value) => new Person.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (nextPageToken != null) { |
| _json["nextPageToken"] = nextPageToken; |
| } |
| if (nextSyncToken != null) { |
| _json["nextSyncToken"] = nextSyncToken; |
| } |
| if (people != null) { |
| _json["people"] = people.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a request for the authenticated user's "Other contacts". |
| class ListOtherContactsResponse { |
| /// A token, which can be sent as `page_token` to retrieve the next page. If |
| /// this field is omitted, there are no subsequent pages. |
| core.String nextPageToken; |
| |
| /// A token, which can be sent as `sync_token` to retrieve changes since the |
| /// last request. Request must set `request_sync_token` to return the sync |
| /// token. |
| core.String nextSyncToken; |
| |
| /// The list of "Other contacts" returned as Person resources. "Other |
| /// contacts" support a limited subset of fields. See |
| /// ListOtherContactsRequest.request_mask for more detailed information. |
| core.List<Person> otherContacts; |
| |
| ListOtherContactsResponse(); |
| |
| ListOtherContactsResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("nextPageToken")) { |
| nextPageToken = _json["nextPageToken"]; |
| } |
| if (_json.containsKey("nextSyncToken")) { |
| nextSyncToken = _json["nextSyncToken"]; |
| } |
| if (_json.containsKey("otherContacts")) { |
| otherContacts = (_json["otherContacts"] as core.List) |
| .map<Person>((value) => new Person.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (nextPageToken != null) { |
| _json["nextPageToken"] = nextPageToken; |
| } |
| if (nextSyncToken != null) { |
| _json["nextSyncToken"] = nextSyncToken; |
| } |
| if (otherContacts != null) { |
| _json["otherContacts"] = |
| otherContacts.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's locale preference. |
| class Locale { |
| /// Metadata about the locale. |
| FieldMetadata metadata; |
| |
| /// The well-formed [IETF BCP 47](https://tools.ietf.org/html/bcp47) language |
| /// tag representing the locale. |
| core.String value; |
| |
| Locale(); |
| |
| Locale.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's location. |
| class Location { |
| /// The building identifier. |
| core.String buildingId; |
| |
| /// Whether the location is the current location. |
| core.bool current; |
| |
| /// The individual desk location. |
| core.String deskCode; |
| |
| /// The floor name or number. |
| core.String floor; |
| |
| /// The floor section in `floor_name`. |
| core.String floorSection; |
| |
| /// Metadata about the location. |
| FieldMetadata metadata; |
| |
| /// The type of the location. The type can be custom or one of these |
| /// predefined values: * `desk` * `grewUp` |
| core.String type; |
| |
| /// The free-form value of the location. |
| core.String value; |
| |
| Location(); |
| |
| Location.fromJson(core.Map _json) { |
| if (_json.containsKey("buildingId")) { |
| buildingId = _json["buildingId"]; |
| } |
| if (_json.containsKey("current")) { |
| current = _json["current"]; |
| } |
| if (_json.containsKey("deskCode")) { |
| deskCode = _json["deskCode"]; |
| } |
| if (_json.containsKey("floor")) { |
| floor = _json["floor"]; |
| } |
| if (_json.containsKey("floorSection")) { |
| floorSection = _json["floorSection"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (buildingId != null) { |
| _json["buildingId"] = buildingId; |
| } |
| if (current != null) { |
| _json["current"] = current; |
| } |
| if (deskCode != null) { |
| _json["deskCode"] = deskCode; |
| } |
| if (floor != null) { |
| _json["floor"] = floor; |
| } |
| if (floorSection != null) { |
| _json["floorSection"] = floorSection; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's membership in a group. Only contact group memberships can be |
| /// modified. |
| class Membership { |
| /// The contact group membership. |
| ContactGroupMembership contactGroupMembership; |
| |
| /// Output only. The domain membership. |
| DomainMembership domainMembership; |
| |
| /// Metadata about the membership. |
| FieldMetadata metadata; |
| |
| Membership(); |
| |
| Membership.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroupMembership")) { |
| contactGroupMembership = |
| new ContactGroupMembership.fromJson(_json["contactGroupMembership"]); |
| } |
| if (_json.containsKey("domainMembership")) { |
| domainMembership = |
| new DomainMembership.fromJson(_json["domainMembership"]); |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroupMembership != null) { |
| _json["contactGroupMembership"] = (contactGroupMembership).toJson(); |
| } |
| if (domainMembership != null) { |
| _json["domainMembership"] = (domainMembership).toJson(); |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's miscellaneous keyword. |
| class MiscKeyword { |
| /// Output only. The type of the miscellaneous keyword translated and |
| /// formatted in the viewer's account locale or the `Accept-Language` HTTP |
| /// header locale. |
| core.String formattedType; |
| |
| /// Metadata about the miscellaneous keyword. |
| FieldMetadata metadata; |
| |
| /// The miscellaneous keyword type. |
| /// Possible string values are: |
| /// - "TYPE_UNSPECIFIED" : Unspecified. |
| /// - "OUTLOOK_BILLING_INFORMATION" : Outlook field for billing information. |
| /// - "OUTLOOK_DIRECTORY_SERVER" : Outlook field for directory server. |
| /// - "OUTLOOK_KEYWORD" : Outlook field for keyword. |
| /// - "OUTLOOK_MILEAGE" : Outlook field for mileage. |
| /// - "OUTLOOK_PRIORITY" : Outlook field for priority. |
| /// - "OUTLOOK_SENSITIVITY" : Outlook field for sensitivity. |
| /// - "OUTLOOK_SUBJECT" : Outlook field for subject. |
| /// - "OUTLOOK_USER" : Outlook field for user. |
| /// - "HOME" : Home. |
| /// - "WORK" : Work. |
| /// - "OTHER" : Other. |
| core.String type; |
| |
| /// The value of the miscellaneous keyword. |
| core.String value; |
| |
| MiscKeyword(); |
| |
| MiscKeyword.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A request to modify an existing contact group's members. Contacts can be |
| /// removed from any group but they can only be added to a user group or |
| /// "myContacts" or "starred" system groups. |
| class ModifyContactGroupMembersRequest { |
| /// Optional. The resource names of the contact people to add in the form of |
| /// `people/{person_id}`. |
| core.List<core.String> resourceNamesToAdd; |
| |
| /// Optional. The resource names of the contact people to remove in the form |
| /// of `people/{person_id}`. |
| core.List<core.String> resourceNamesToRemove; |
| |
| ModifyContactGroupMembersRequest(); |
| |
| ModifyContactGroupMembersRequest.fromJson(core.Map _json) { |
| if (_json.containsKey("resourceNamesToAdd")) { |
| resourceNamesToAdd = |
| (_json["resourceNamesToAdd"] as core.List).cast<core.String>(); |
| } |
| if (_json.containsKey("resourceNamesToRemove")) { |
| resourceNamesToRemove = |
| (_json["resourceNamesToRemove"] as core.List).cast<core.String>(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (resourceNamesToAdd != null) { |
| _json["resourceNamesToAdd"] = resourceNamesToAdd; |
| } |
| if (resourceNamesToRemove != null) { |
| _json["resourceNamesToRemove"] = resourceNamesToRemove; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a modify contact group members request. |
| class ModifyContactGroupMembersResponse { |
| /// The contact people resource names that cannot be removed from their last |
| /// contact group. |
| core.List<core.String> canNotRemoveLastContactGroupResourceNames; |
| |
| /// The contact people resource names that were not found. |
| core.List<core.String> notFoundResourceNames; |
| |
| ModifyContactGroupMembersResponse(); |
| |
| ModifyContactGroupMembersResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("canNotRemoveLastContactGroupResourceNames")) { |
| canNotRemoveLastContactGroupResourceNames = |
| (_json["canNotRemoveLastContactGroupResourceNames"] as core.List) |
| .cast<core.String>(); |
| } |
| if (_json.containsKey("notFoundResourceNames")) { |
| notFoundResourceNames = |
| (_json["notFoundResourceNames"] as core.List).cast<core.String>(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (canNotRemoveLastContactGroupResourceNames != null) { |
| _json["canNotRemoveLastContactGroupResourceNames"] = |
| canNotRemoveLastContactGroupResourceNames; |
| } |
| if (notFoundResourceNames != null) { |
| _json["notFoundResourceNames"] = notFoundResourceNames; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's name. If the name is a mononym, the family name is empty. |
| class Name { |
| /// Output only. The display name formatted according to the locale specified |
| /// by the viewer's account or the `Accept-Language` HTTP header. |
| core.String displayName; |
| |
| /// Output only. The display name with the last name first formatted according |
| /// to the locale specified by the viewer's account or the `Accept-Language` |
| /// HTTP header. |
| core.String displayNameLastFirst; |
| |
| /// The family name. |
| core.String familyName; |
| |
| /// The given name. |
| core.String givenName; |
| |
| /// The honorific prefixes, such as `Mrs.` or `Dr.` |
| core.String honorificPrefix; |
| |
| /// The honorific suffixes, such as `Jr.` |
| core.String honorificSuffix; |
| |
| /// Metadata about the name. |
| FieldMetadata metadata; |
| |
| /// The middle name(s). |
| core.String middleName; |
| |
| /// The family name spelled as it sounds. |
| core.String phoneticFamilyName; |
| |
| /// The full name spelled as it sounds. |
| core.String phoneticFullName; |
| |
| /// The given name spelled as it sounds. |
| core.String phoneticGivenName; |
| |
| /// The honorific prefixes spelled as they sound. |
| core.String phoneticHonorificPrefix; |
| |
| /// The honorific suffixes spelled as they sound. |
| core.String phoneticHonorificSuffix; |
| |
| /// The middle name(s) spelled as they sound. |
| core.String phoneticMiddleName; |
| |
| /// The free form name value. |
| core.String unstructuredName; |
| |
| Name(); |
| |
| Name.fromJson(core.Map _json) { |
| if (_json.containsKey("displayName")) { |
| displayName = _json["displayName"]; |
| } |
| if (_json.containsKey("displayNameLastFirst")) { |
| displayNameLastFirst = _json["displayNameLastFirst"]; |
| } |
| if (_json.containsKey("familyName")) { |
| familyName = _json["familyName"]; |
| } |
| if (_json.containsKey("givenName")) { |
| givenName = _json["givenName"]; |
| } |
| if (_json.containsKey("honorificPrefix")) { |
| honorificPrefix = _json["honorificPrefix"]; |
| } |
| if (_json.containsKey("honorificSuffix")) { |
| honorificSuffix = _json["honorificSuffix"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("middleName")) { |
| middleName = _json["middleName"]; |
| } |
| if (_json.containsKey("phoneticFamilyName")) { |
| phoneticFamilyName = _json["phoneticFamilyName"]; |
| } |
| if (_json.containsKey("phoneticFullName")) { |
| phoneticFullName = _json["phoneticFullName"]; |
| } |
| if (_json.containsKey("phoneticGivenName")) { |
| phoneticGivenName = _json["phoneticGivenName"]; |
| } |
| if (_json.containsKey("phoneticHonorificPrefix")) { |
| phoneticHonorificPrefix = _json["phoneticHonorificPrefix"]; |
| } |
| if (_json.containsKey("phoneticHonorificSuffix")) { |
| phoneticHonorificSuffix = _json["phoneticHonorificSuffix"]; |
| } |
| if (_json.containsKey("phoneticMiddleName")) { |
| phoneticMiddleName = _json["phoneticMiddleName"]; |
| } |
| if (_json.containsKey("unstructuredName")) { |
| unstructuredName = _json["unstructuredName"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (displayName != null) { |
| _json["displayName"] = displayName; |
| } |
| if (displayNameLastFirst != null) { |
| _json["displayNameLastFirst"] = displayNameLastFirst; |
| } |
| if (familyName != null) { |
| _json["familyName"] = familyName; |
| } |
| if (givenName != null) { |
| _json["givenName"] = givenName; |
| } |
| if (honorificPrefix != null) { |
| _json["honorificPrefix"] = honorificPrefix; |
| } |
| if (honorificSuffix != null) { |
| _json["honorificSuffix"] = honorificSuffix; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (middleName != null) { |
| _json["middleName"] = middleName; |
| } |
| if (phoneticFamilyName != null) { |
| _json["phoneticFamilyName"] = phoneticFamilyName; |
| } |
| if (phoneticFullName != null) { |
| _json["phoneticFullName"] = phoneticFullName; |
| } |
| if (phoneticGivenName != null) { |
| _json["phoneticGivenName"] = phoneticGivenName; |
| } |
| if (phoneticHonorificPrefix != null) { |
| _json["phoneticHonorificPrefix"] = phoneticHonorificPrefix; |
| } |
| if (phoneticHonorificSuffix != null) { |
| _json["phoneticHonorificSuffix"] = phoneticHonorificSuffix; |
| } |
| if (phoneticMiddleName != null) { |
| _json["phoneticMiddleName"] = phoneticMiddleName; |
| } |
| if (unstructuredName != null) { |
| _json["unstructuredName"] = unstructuredName; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's nickname. |
| class Nickname { |
| /// Metadata about the nickname. |
| FieldMetadata metadata; |
| |
| /// The type of the nickname. |
| /// Possible string values are: |
| /// - "DEFAULT" : Generic nickname. |
| /// - "MAIDEN_NAME" : Maiden name or birth family name. Used when the person's |
| /// family name has changed as a result of marriage. |
| /// - "INITIALS" : Initials. |
| /// - "GPLUS" : Google+ profile nickname. |
| /// - "OTHER_NAME" : A professional affiliation or other name; for example, |
| /// `Dr. Smith.` |
| /// - "ALTERNATE_NAME" : Alternate name person is known by. |
| /// - "SHORT_NAME" : A shorter version of the person's name. |
| core.String type; |
| |
| /// The nickname. |
| core.String value; |
| |
| Nickname(); |
| |
| Nickname.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's occupation. |
| class Occupation { |
| /// Metadata about the occupation. |
| FieldMetadata metadata; |
| |
| /// The occupation; for example, `carpenter`. |
| core.String value; |
| |
| Occupation(); |
| |
| Occupation.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's past or current organization. Overlapping date ranges are |
| /// permitted. |
| class Organization { |
| /// True if the organization is the person's current organization; false if |
| /// the organization is a past organization. |
| core.bool current; |
| |
| /// The person's department at the organization. |
| core.String department; |
| |
| /// The domain name associated with the organization; for example, |
| /// `google.com`. |
| core.String domain; |
| |
| /// The end date when the person left the organization. |
| Date endDate; |
| |
| /// Output only. The type of the organization translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// The person's job description at the organization. |
| core.String jobDescription; |
| |
| /// The location of the organization office the person works at. |
| core.String location; |
| |
| /// Metadata about the organization. |
| FieldMetadata metadata; |
| |
| /// The name of the organization. |
| core.String name; |
| |
| /// The phonetic name of the organization. |
| core.String phoneticName; |
| |
| /// The start date when the person joined the organization. |
| Date startDate; |
| |
| /// The symbol associated with the organization; for example, a stock ticker |
| /// symbol, abbreviation, or acronym. |
| core.String symbol; |
| |
| /// The person's job title at the organization. |
| core.String title; |
| |
| /// The type of the organization. The type can be custom or one of these |
| /// predefined values: * `work` * `school` |
| core.String type; |
| |
| Organization(); |
| |
| Organization.fromJson(core.Map _json) { |
| if (_json.containsKey("current")) { |
| current = _json["current"]; |
| } |
| if (_json.containsKey("department")) { |
| department = _json["department"]; |
| } |
| if (_json.containsKey("domain")) { |
| domain = _json["domain"]; |
| } |
| if (_json.containsKey("endDate")) { |
| endDate = new Date.fromJson(_json["endDate"]); |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("jobDescription")) { |
| jobDescription = _json["jobDescription"]; |
| } |
| if (_json.containsKey("location")) { |
| location = _json["location"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("name")) { |
| name = _json["name"]; |
| } |
| if (_json.containsKey("phoneticName")) { |
| phoneticName = _json["phoneticName"]; |
| } |
| if (_json.containsKey("startDate")) { |
| startDate = new Date.fromJson(_json["startDate"]); |
| } |
| if (_json.containsKey("symbol")) { |
| symbol = _json["symbol"]; |
| } |
| if (_json.containsKey("title")) { |
| title = _json["title"]; |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (current != null) { |
| _json["current"] = current; |
| } |
| if (department != null) { |
| _json["department"] = department; |
| } |
| if (domain != null) { |
| _json["domain"] = domain; |
| } |
| if (endDate != null) { |
| _json["endDate"] = (endDate).toJson(); |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (jobDescription != null) { |
| _json["jobDescription"] = jobDescription; |
| } |
| if (location != null) { |
| _json["location"] = location; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (name != null) { |
| _json["name"] = name; |
| } |
| if (phoneticName != null) { |
| _json["phoneticName"] = phoneticName; |
| } |
| if (startDate != null) { |
| _json["startDate"] = (startDate).toJson(); |
| } |
| if (symbol != null) { |
| _json["symbol"] = symbol; |
| } |
| if (title != null) { |
| _json["title"] = title; |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| return _json; |
| } |
| } |
| |
| /// Information about a person merged from various data sources such as the |
| /// authenticated user's contacts and profile data. Most fields can have |
| /// multiple items. The items in a field have no guaranteed order, but each |
| /// non-empty field is guaranteed to have exactly one field with |
| /// `metadata.primary` set to true. |
| class Person { |
| /// The person's street addresses. |
| core.List<Address> addresses; |
| |
| /// Output only. **DEPRECATED** (Please use `person.ageRanges` instead) The |
| /// person's age range. |
| /// Possible string values are: |
| /// - "AGE_RANGE_UNSPECIFIED" : Unspecified. |
| /// - "LESS_THAN_EIGHTEEN" : Younger than eighteen. |
| /// - "EIGHTEEN_TO_TWENTY" : Between eighteen and twenty. |
| /// - "TWENTY_ONE_OR_OLDER" : Twenty-one and older. |
| core.String ageRange; |
| |
| /// Output only. The person's age ranges. |
| core.List<AgeRangeType> ageRanges; |
| |
| /// The person's biographies. This field is a singleton for contact sources. |
| core.List<Biography> biographies; |
| |
| /// The person's birthdays. This field is a singleton for contact sources. |
| core.List<Birthday> birthdays; |
| |
| /// **DEPRECATED**: No data will be returned The person's bragging rights. |
| core.List<BraggingRights> braggingRights; |
| |
| /// The person's calendar URLs. |
| core.List<CalendarUrl> calendarUrls; |
| |
| /// The person's client data. |
| core.List<ClientData> clientData; |
| |
| /// Output only. The person's cover photos. |
| core.List<CoverPhoto> coverPhotos; |
| |
| /// The person's email addresses. |
| core.List<EmailAddress> emailAddresses; |
| |
| /// The [HTTP entity tag](https://en.wikipedia.org/wiki/HTTP_ETag) of the |
| /// resource. Used for web cache validation. |
| core.String etag; |
| |
| /// The person's events. |
| core.List<Event> events; |
| |
| /// The person's external IDs. |
| core.List<ExternalId> externalIds; |
| |
| /// The person's file-ases. |
| core.List<FileAs> fileAses; |
| |
| /// The person's genders. This field is a singleton for contact sources. |
| core.List<Gender> genders; |
| |
| /// The person's instant messaging clients. |
| core.List<ImClient> imClients; |
| |
| /// The person's interests. |
| core.List<Interest> interests; |
| |
| /// The person's locale preferences. |
| core.List<Locale> locales; |
| |
| /// The person's locations. |
| core.List<Location> locations; |
| |
| /// The person's group memberships. |
| core.List<Membership> memberships; |
| |
| /// Output only. Metadata about the person. |
| PersonMetadata metadata; |
| |
| /// The person's miscellaneous keywords. |
| core.List<MiscKeyword> miscKeywords; |
| |
| /// The person's names. This field is a singleton for contact sources. |
| core.List<Name> names; |
| |
| /// The person's nicknames. |
| core.List<Nickname> nicknames; |
| |
| /// The person's occupations. |
| core.List<Occupation> occupations; |
| |
| /// The person's past or current organizations. |
| core.List<Organization> organizations; |
| |
| /// The person's phone numbers. |
| core.List<PhoneNumber> phoneNumbers; |
| |
| /// Output only. The person's photos. |
| core.List<Photo> photos; |
| |
| /// The person's relations. |
| core.List<Relation> relations; |
| |
| /// Output only. **DEPRECATED**: No data will be returned The person's |
| /// relationship interests. |
| core.List<RelationshipInterest> relationshipInterests; |
| |
| /// Output only. **DEPRECATED**: No data will be returned The person's |
| /// relationship statuses. |
| core.List<RelationshipStatus> relationshipStatuses; |
| |
| /// **DEPRECATED**: (Please use `person.locations` instead) The person's |
| /// residences. |
| core.List<Residence> residences; |
| |
| /// The resource name for the person, assigned by the server. An ASCII string |
| /// with a max length of 27 characters, in the form of `people/{person_id}`. |
| core.String resourceName; |
| |
| /// The person's SIP addresses. |
| core.List<SipAddress> sipAddresses; |
| |
| /// The person's skills. |
| core.List<Skill> skills; |
| |
| /// Output only. **DEPRECATED**: No data will be returned The person's |
| /// taglines. |
| core.List<Tagline> taglines; |
| |
| /// The person's associated URLs. |
| core.List<Url> urls; |
| |
| /// The person's user defined data. |
| core.List<UserDefined> userDefined; |
| |
| Person(); |
| |
| Person.fromJson(core.Map _json) { |
| if (_json.containsKey("addresses")) { |
| addresses = (_json["addresses"] as core.List) |
| .map<Address>((value) => new Address.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("ageRange")) { |
| ageRange = _json["ageRange"]; |
| } |
| if (_json.containsKey("ageRanges")) { |
| ageRanges = (_json["ageRanges"] as core.List) |
| .map<AgeRangeType>((value) => new AgeRangeType.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("biographies")) { |
| biographies = (_json["biographies"] as core.List) |
| .map<Biography>((value) => new Biography.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("birthdays")) { |
| birthdays = (_json["birthdays"] as core.List) |
| .map<Birthday>((value) => new Birthday.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("braggingRights")) { |
| braggingRights = (_json["braggingRights"] as core.List) |
| .map<BraggingRights>((value) => new BraggingRights.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("calendarUrls")) { |
| calendarUrls = (_json["calendarUrls"] as core.List) |
| .map<CalendarUrl>((value) => new CalendarUrl.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("clientData")) { |
| clientData = (_json["clientData"] as core.List) |
| .map<ClientData>((value) => new ClientData.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("coverPhotos")) { |
| coverPhotos = (_json["coverPhotos"] as core.List) |
| .map<CoverPhoto>((value) => new CoverPhoto.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("emailAddresses")) { |
| emailAddresses = (_json["emailAddresses"] as core.List) |
| .map<EmailAddress>((value) => new EmailAddress.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("etag")) { |
| etag = _json["etag"]; |
| } |
| if (_json.containsKey("events")) { |
| events = (_json["events"] as core.List) |
| .map<Event>((value) => new Event.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("externalIds")) { |
| externalIds = (_json["externalIds"] as core.List) |
| .map<ExternalId>((value) => new ExternalId.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("fileAses")) { |
| fileAses = (_json["fileAses"] as core.List) |
| .map<FileAs>((value) => new FileAs.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("genders")) { |
| genders = (_json["genders"] as core.List) |
| .map<Gender>((value) => new Gender.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("imClients")) { |
| imClients = (_json["imClients"] as core.List) |
| .map<ImClient>((value) => new ImClient.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("interests")) { |
| interests = (_json["interests"] as core.List) |
| .map<Interest>((value) => new Interest.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("locales")) { |
| locales = (_json["locales"] as core.List) |
| .map<Locale>((value) => new Locale.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("locations")) { |
| locations = (_json["locations"] as core.List) |
| .map<Location>((value) => new Location.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("memberships")) { |
| memberships = (_json["memberships"] as core.List) |
| .map<Membership>((value) => new Membership.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new PersonMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("miscKeywords")) { |
| miscKeywords = (_json["miscKeywords"] as core.List) |
| .map<MiscKeyword>((value) => new MiscKeyword.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("names")) { |
| names = (_json["names"] as core.List) |
| .map<Name>((value) => new Name.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("nicknames")) { |
| nicknames = (_json["nicknames"] as core.List) |
| .map<Nickname>((value) => new Nickname.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("occupations")) { |
| occupations = (_json["occupations"] as core.List) |
| .map<Occupation>((value) => new Occupation.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("organizations")) { |
| organizations = (_json["organizations"] as core.List) |
| .map<Organization>((value) => new Organization.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("phoneNumbers")) { |
| phoneNumbers = (_json["phoneNumbers"] as core.List) |
| .map<PhoneNumber>((value) => new PhoneNumber.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("photos")) { |
| photos = (_json["photos"] as core.List) |
| .map<Photo>((value) => new Photo.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("relations")) { |
| relations = (_json["relations"] as core.List) |
| .map<Relation>((value) => new Relation.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("relationshipInterests")) { |
| relationshipInterests = (_json["relationshipInterests"] as core.List) |
| .map<RelationshipInterest>( |
| (value) => new RelationshipInterest.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("relationshipStatuses")) { |
| relationshipStatuses = (_json["relationshipStatuses"] as core.List) |
| .map<RelationshipStatus>( |
| (value) => new RelationshipStatus.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("residences")) { |
| residences = (_json["residences"] as core.List) |
| .map<Residence>((value) => new Residence.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("resourceName")) { |
| resourceName = _json["resourceName"]; |
| } |
| if (_json.containsKey("sipAddresses")) { |
| sipAddresses = (_json["sipAddresses"] as core.List) |
| .map<SipAddress>((value) => new SipAddress.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("skills")) { |
| skills = (_json["skills"] as core.List) |
| .map<Skill>((value) => new Skill.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("taglines")) { |
| taglines = (_json["taglines"] as core.List) |
| .map<Tagline>((value) => new Tagline.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("urls")) { |
| urls = (_json["urls"] as core.List) |
| .map<Url>((value) => new Url.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("userDefined")) { |
| userDefined = (_json["userDefined"] as core.List) |
| .map<UserDefined>((value) => new UserDefined.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (addresses != null) { |
| _json["addresses"] = addresses.map((value) => (value).toJson()).toList(); |
| } |
| if (ageRange != null) { |
| _json["ageRange"] = ageRange; |
| } |
| if (ageRanges != null) { |
| _json["ageRanges"] = ageRanges.map((value) => (value).toJson()).toList(); |
| } |
| if (biographies != null) { |
| _json["biographies"] = |
| biographies.map((value) => (value).toJson()).toList(); |
| } |
| if (birthdays != null) { |
| _json["birthdays"] = birthdays.map((value) => (value).toJson()).toList(); |
| } |
| if (braggingRights != null) { |
| _json["braggingRights"] = |
| braggingRights.map((value) => (value).toJson()).toList(); |
| } |
| if (calendarUrls != null) { |
| _json["calendarUrls"] = |
| calendarUrls.map((value) => (value).toJson()).toList(); |
| } |
| if (clientData != null) { |
| _json["clientData"] = |
| clientData.map((value) => (value).toJson()).toList(); |
| } |
| if (coverPhotos != null) { |
| _json["coverPhotos"] = |
| coverPhotos.map((value) => (value).toJson()).toList(); |
| } |
| if (emailAddresses != null) { |
| _json["emailAddresses"] = |
| emailAddresses.map((value) => (value).toJson()).toList(); |
| } |
| if (etag != null) { |
| _json["etag"] = etag; |
| } |
| if (events != null) { |
| _json["events"] = events.map((value) => (value).toJson()).toList(); |
| } |
| if (externalIds != null) { |
| _json["externalIds"] = |
| externalIds.map((value) => (value).toJson()).toList(); |
| } |
| if (fileAses != null) { |
| _json["fileAses"] = fileAses.map((value) => (value).toJson()).toList(); |
| } |
| if (genders != null) { |
| _json["genders"] = genders.map((value) => (value).toJson()).toList(); |
| } |
| if (imClients != null) { |
| _json["imClients"] = imClients.map((value) => (value).toJson()).toList(); |
| } |
| if (interests != null) { |
| _json["interests"] = interests.map((value) => (value).toJson()).toList(); |
| } |
| if (locales != null) { |
| _json["locales"] = locales.map((value) => (value).toJson()).toList(); |
| } |
| if (locations != null) { |
| _json["locations"] = locations.map((value) => (value).toJson()).toList(); |
| } |
| if (memberships != null) { |
| _json["memberships"] = |
| memberships.map((value) => (value).toJson()).toList(); |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (miscKeywords != null) { |
| _json["miscKeywords"] = |
| miscKeywords.map((value) => (value).toJson()).toList(); |
| } |
| if (names != null) { |
| _json["names"] = names.map((value) => (value).toJson()).toList(); |
| } |
| if (nicknames != null) { |
| _json["nicknames"] = nicknames.map((value) => (value).toJson()).toList(); |
| } |
| if (occupations != null) { |
| _json["occupations"] = |
| occupations.map((value) => (value).toJson()).toList(); |
| } |
| if (organizations != null) { |
| _json["organizations"] = |
| organizations.map((value) => (value).toJson()).toList(); |
| } |
| if (phoneNumbers != null) { |
| _json["phoneNumbers"] = |
| phoneNumbers.map((value) => (value).toJson()).toList(); |
| } |
| if (photos != null) { |
| _json["photos"] = photos.map((value) => (value).toJson()).toList(); |
| } |
| if (relations != null) { |
| _json["relations"] = relations.map((value) => (value).toJson()).toList(); |
| } |
| if (relationshipInterests != null) { |
| _json["relationshipInterests"] = |
| relationshipInterests.map((value) => (value).toJson()).toList(); |
| } |
| if (relationshipStatuses != null) { |
| _json["relationshipStatuses"] = |
| relationshipStatuses.map((value) => (value).toJson()).toList(); |
| } |
| if (residences != null) { |
| _json["residences"] = |
| residences.map((value) => (value).toJson()).toList(); |
| } |
| if (resourceName != null) { |
| _json["resourceName"] = resourceName; |
| } |
| if (sipAddresses != null) { |
| _json["sipAddresses"] = |
| sipAddresses.map((value) => (value).toJson()).toList(); |
| } |
| if (skills != null) { |
| _json["skills"] = skills.map((value) => (value).toJson()).toList(); |
| } |
| if (taglines != null) { |
| _json["taglines"] = taglines.map((value) => (value).toJson()).toList(); |
| } |
| if (urls != null) { |
| _json["urls"] = urls.map((value) => (value).toJson()).toList(); |
| } |
| if (userDefined != null) { |
| _json["userDefined"] = |
| userDefined.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// The metadata about a person. |
| class PersonMetadata { |
| /// Output only. True if the person resource has been deleted. Populated only |
| /// for [`connections.list`](/people/api/rest/v1/people.connections/list) |
| /// requests that include a sync token. |
| core.bool deleted; |
| |
| /// Output only. Resource names of people linked to this resource. |
| core.List<core.String> linkedPeopleResourceNames; |
| |
| /// Output only. **DEPRECATED** (Please use |
| /// `person.metadata.sources.profileMetadata.objectType` instead) The type of |
| /// the person object. |
| /// Possible string values are: |
| /// - "OBJECT_TYPE_UNSPECIFIED" : Unspecified. |
| /// - "PERSON" : Person. |
| /// - "PAGE" : [Currents Page.](https://gsuite.google.com/products/currents/) |
| core.String objectType; |
| |
| /// Output only. Any former resource names this person has had. Populated only |
| /// for [`connections.list`](/people/api/rest/v1/people.connections/list) |
| /// requests that include a sync token. The resource name may change when |
| /// adding or removing fields that link a contact and profile such as a |
| /// verified email, verified phone number, or profile URL. |
| core.List<core.String> previousResourceNames; |
| |
| /// The sources of data for the person. |
| core.List<Source> sources; |
| |
| PersonMetadata(); |
| |
| PersonMetadata.fromJson(core.Map _json) { |
| if (_json.containsKey("deleted")) { |
| deleted = _json["deleted"]; |
| } |
| if (_json.containsKey("linkedPeopleResourceNames")) { |
| linkedPeopleResourceNames = |
| (_json["linkedPeopleResourceNames"] as core.List).cast<core.String>(); |
| } |
| if (_json.containsKey("objectType")) { |
| objectType = _json["objectType"]; |
| } |
| if (_json.containsKey("previousResourceNames")) { |
| previousResourceNames = |
| (_json["previousResourceNames"] as core.List).cast<core.String>(); |
| } |
| if (_json.containsKey("sources")) { |
| sources = (_json["sources"] as core.List) |
| .map<Source>((value) => new Source.fromJson(value)) |
| .toList(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (deleted != null) { |
| _json["deleted"] = deleted; |
| } |
| if (linkedPeopleResourceNames != null) { |
| _json["linkedPeopleResourceNames"] = linkedPeopleResourceNames; |
| } |
| if (objectType != null) { |
| _json["objectType"] = objectType; |
| } |
| if (previousResourceNames != null) { |
| _json["previousResourceNames"] = previousResourceNames; |
| } |
| if (sources != null) { |
| _json["sources"] = sources.map((value) => (value).toJson()).toList(); |
| } |
| return _json; |
| } |
| } |
| |
| /// The response for a single person |
| class PersonResponse { |
| /// **DEPRECATED** (Please use status instead) [HTTP 1.1 status code] |
| /// (http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html). |
| core.int httpStatusCode; |
| |
| /// The person. |
| Person person; |
| |
| /// The original requested resource name. May be different than the resource |
| /// name on the returned person. The resource name can change when adding or |
| /// removing fields that link a contact and profile such as a verified email, |
| /// verified phone number, or a profile URL. |
| core.String requestedResourceName; |
| |
| /// The status of the response. |
| Status status; |
| |
| PersonResponse(); |
| |
| PersonResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("httpStatusCode")) { |
| httpStatusCode = _json["httpStatusCode"]; |
| } |
| if (_json.containsKey("person")) { |
| person = new Person.fromJson(_json["person"]); |
| } |
| if (_json.containsKey("requestedResourceName")) { |
| requestedResourceName = _json["requestedResourceName"]; |
| } |
| if (_json.containsKey("status")) { |
| status = new Status.fromJson(_json["status"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (httpStatusCode != null) { |
| _json["httpStatusCode"] = httpStatusCode; |
| } |
| if (person != null) { |
| _json["person"] = (person).toJson(); |
| } |
| if (requestedResourceName != null) { |
| _json["requestedResourceName"] = requestedResourceName; |
| } |
| if (status != null) { |
| _json["status"] = (status).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's phone number. |
| class PhoneNumber { |
| /// Output only. The canonicalized [ITU-T |
| /// E.164](https://law.resource.org/pub/us/cfr/ibr/004/itu-t.E.164.1.2008.pdf) |
| /// form of the phone number. |
| core.String canonicalForm; |
| |
| /// Output only. The type of the phone number translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the phone number. |
| FieldMetadata metadata; |
| |
| /// The type of the phone number. The type can be custom or one of these |
| /// predefined values: * `home` * `work` * `mobile` * `homeFax` * `workFax` * |
| /// `otherFax` * `pager` * `workMobile` * `workPager` * `main` * `googleVoice` |
| /// * `other` |
| core.String type; |
| |
| /// The phone number. |
| core.String value; |
| |
| PhoneNumber(); |
| |
| PhoneNumber.fromJson(core.Map _json) { |
| if (_json.containsKey("canonicalForm")) { |
| canonicalForm = _json["canonicalForm"]; |
| } |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (canonicalForm != null) { |
| _json["canonicalForm"] = canonicalForm; |
| } |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's photo. A picture shown next to the person's name to help others |
| /// recognize the person. |
| class Photo { |
| /// True if the photo is a default photo; false if the photo is a |
| /// user-provided photo. |
| core.bool default_; |
| |
| /// Metadata about the photo. |
| FieldMetadata metadata; |
| |
| /// The URL of the photo. You can change the desired size by appending a query |
| /// parameter `sz={size}` at the end of the url, where {size} is the size in |
| /// pixels. Example: |
| /// https://lh3.googleusercontent.com/-T_wVWLlmg7w/AAAAAAAAAAI/AAAAAAAABa8/00gzXvDBYqw/s100/photo.jpg?sz=50 |
| core.String url; |
| |
| Photo(); |
| |
| Photo.fromJson(core.Map _json) { |
| if (_json.containsKey("default")) { |
| default_ = _json["default"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("url")) { |
| url = _json["url"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (default_ != null) { |
| _json["default"] = default_; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (url != null) { |
| _json["url"] = url; |
| } |
| return _json; |
| } |
| } |
| |
| /// The metadata about a profile. |
| class ProfileMetadata { |
| /// Output only. The profile object type. |
| /// Possible string values are: |
| /// - "OBJECT_TYPE_UNSPECIFIED" : Unspecified. |
| /// - "PERSON" : Person. |
| /// - "PAGE" : [Currents Page.](https://gsuite.google.com/products/currents/) |
| core.String objectType; |
| |
| /// Output only. The user types. |
| core.List<core.String> userTypes; |
| |
| ProfileMetadata(); |
| |
| ProfileMetadata.fromJson(core.Map _json) { |
| if (_json.containsKey("objectType")) { |
| objectType = _json["objectType"]; |
| } |
| if (_json.containsKey("userTypes")) { |
| userTypes = (_json["userTypes"] as core.List).cast<core.String>(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (objectType != null) { |
| _json["objectType"] = objectType; |
| } |
| if (userTypes != null) { |
| _json["userTypes"] = userTypes; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's relation to another person. |
| class Relation { |
| /// Output only. The type of the relation translated and formatted in the |
| /// viewer's account locale or the locale specified in the Accept-Language |
| /// HTTP header. |
| core.String formattedType; |
| |
| /// Metadata about the relation. |
| FieldMetadata metadata; |
| |
| /// The name of the other person this relation refers to. |
| core.String person; |
| |
| /// The person's relation to the other person. The type can be custom or one |
| /// of these predefined values: * `spouse` * `child` * `mother` * `father` * |
| /// `parent` * `brother` * `sister` * `friend` * `relative` * |
| /// `domesticPartner` * `manager` * `assistant` * `referredBy` * `partner` |
| core.String type; |
| |
| Relation(); |
| |
| Relation.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("person")) { |
| person = _json["person"]; |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (person != null) { |
| _json["person"] = person; |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| return _json; |
| } |
| } |
| |
| /// **DEPRECATED**: No data will be returned A person's relationship interest . |
| class RelationshipInterest { |
| /// Output only. The value of the relationship interest translated and |
| /// formatted in the viewer's account locale or the locale specified in the |
| /// Accept-Language HTTP header. |
| core.String formattedValue; |
| |
| /// Metadata about the relationship interest. |
| FieldMetadata metadata; |
| |
| /// The kind of relationship the person is looking for. The value can be |
| /// custom or one of these predefined values: * `friend` * `date` * |
| /// `relationship` * `networking` |
| core.String value; |
| |
| RelationshipInterest(); |
| |
| RelationshipInterest.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedValue")) { |
| formattedValue = _json["formattedValue"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedValue != null) { |
| _json["formattedValue"] = formattedValue; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// **DEPRECATED**: No data will be returned A person's relationship status. |
| class RelationshipStatus { |
| /// Output only. The value of the relationship status translated and formatted |
| /// in the viewer's account locale or the `Accept-Language` HTTP header |
| /// locale. |
| core.String formattedValue; |
| |
| /// Metadata about the relationship status. |
| FieldMetadata metadata; |
| |
| /// The relationship status. The value can be custom or one of these |
| /// predefined values: * `single` * `inARelationship` * `engaged` * `married` |
| /// * `itsComplicated` * `openRelationship` * `widowed` * |
| /// `inDomesticPartnership` * `inCivilUnion` |
| core.String value; |
| |
| RelationshipStatus(); |
| |
| RelationshipStatus.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedValue")) { |
| formattedValue = _json["formattedValue"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedValue != null) { |
| _json["formattedValue"] = formattedValue; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// **DEPRECATED**: Please use `person.locations` instead. A person's past or |
| /// current residence. |
| class Residence { |
| /// True if the residence is the person's current residence; false if the |
| /// residence is a past residence. |
| core.bool current; |
| |
| /// Metadata about the residence. |
| FieldMetadata metadata; |
| |
| /// The address of the residence. |
| core.String value; |
| |
| Residence(); |
| |
| Residence.fromJson(core.Map _json) { |
| if (_json.containsKey("current")) { |
| current = _json["current"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (current != null) { |
| _json["current"] = current; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response to a request for people in the authenticated user's domain |
| /// directory that match the specified query. |
| class SearchDirectoryPeopleResponse { |
| /// A token, which can be sent as `page_token` to retrieve the next page. If |
| /// this field is omitted, there are no subsequent pages. |
| core.String nextPageToken; |
| |
| /// The list of people in the domain directory that match the query. |
| core.List<Person> people; |
| |
| /// The total number of items in the list without pagination. |
| core.int totalSize; |
| |
| SearchDirectoryPeopleResponse(); |
| |
| SearchDirectoryPeopleResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("nextPageToken")) { |
| nextPageToken = _json["nextPageToken"]; |
| } |
| if (_json.containsKey("people")) { |
| people = (_json["people"] as core.List) |
| .map<Person>((value) => new Person.fromJson(value)) |
| .toList(); |
| } |
| if (_json.containsKey("totalSize")) { |
| totalSize = _json["totalSize"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (nextPageToken != null) { |
| _json["nextPageToken"] = nextPageToken; |
| } |
| if (people != null) { |
| _json["people"] = people.map((value) => (value).toJson()).toList(); |
| } |
| if (totalSize != null) { |
| _json["totalSize"] = totalSize; |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's SIP address. Session Initial Protocol addresses are used for VoIP |
| /// communications to make voice or video calls over the internet. |
| class SipAddress { |
| /// Output only. The type of the SIP address translated and formatted in the |
| /// viewer's account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the SIP address. |
| FieldMetadata metadata; |
| |
| /// The type of the SIP address. The type can be custom or or one of these |
| /// predefined values: * `home` * `work` * `mobile` * `other` |
| core.String type; |
| |
| /// The SIP address in the [RFC 3261 |
| /// 19.1](https://tools.ietf.org/html/rfc3261#section-19.1) SIP URI format. |
| core.String value; |
| |
| SipAddress(); |
| |
| SipAddress.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A skill that the person has. |
| class Skill { |
| /// Metadata about the skill. |
| FieldMetadata metadata; |
| |
| /// The skill; for example, `underwater basket weaving`. |
| core.String value; |
| |
| Skill(); |
| |
| Skill.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// The source of a field. |
| class Source { |
| /// **Only populated in `person.metadata.sources`.** The [HTTP entity |
| /// tag](https://en.wikipedia.org/wiki/HTTP_ETag) of the source. Used for web |
| /// cache validation. |
| core.String etag; |
| |
| /// The unique identifier within the source type generated by the server. |
| core.String id; |
| |
| /// Output only. **Only populated in `person.metadata.sources`.** Metadata |
| /// about a source of type PROFILE. |
| ProfileMetadata profileMetadata; |
| |
| /// The source type. |
| /// Possible string values are: |
| /// - "SOURCE_TYPE_UNSPECIFIED" : Unspecified. |
| /// - "ACCOUNT" : [Google Account](https://accounts.google.com). |
| /// - "PROFILE" : [Google profile](https://profiles.google.com). You can view |
| /// the profile at |
| /// [https://profiles.google.com/](https://profiles.google.com/){id}, where |
| /// {id} is the source id. |
| /// - "DOMAIN_PROFILE" : [G Suite domain |
| /// profile](https://support.google.com/a/answer/1628008). |
| /// - "CONTACT" : [Google contact](https://contacts.google.com). You can view |
| /// the contact at |
| /// [https://contact.google.com/](https://contact.google.com/){id}, where {id} |
| /// is the source id. |
| /// - "OTHER_CONTACT" : [Google "Other |
| /// contact"](https://contacts.google.com/other). |
| /// - "DOMAIN_CONTACT" : [G Suite domain shared |
| /// contact](https://support.google.com/a/answer/9281635). |
| core.String type; |
| |
| /// Output only. **Only populated in `person.metadata.sources`.** Last update |
| /// timestamp of this source. |
| core.String updateTime; |
| |
| Source(); |
| |
| Source.fromJson(core.Map _json) { |
| if (_json.containsKey("etag")) { |
| etag = _json["etag"]; |
| } |
| if (_json.containsKey("id")) { |
| id = _json["id"]; |
| } |
| if (_json.containsKey("profileMetadata")) { |
| profileMetadata = new ProfileMetadata.fromJson(_json["profileMetadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("updateTime")) { |
| updateTime = _json["updateTime"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (etag != null) { |
| _json["etag"] = etag; |
| } |
| if (id != null) { |
| _json["id"] = id; |
| } |
| if (profileMetadata != null) { |
| _json["profileMetadata"] = (profileMetadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (updateTime != null) { |
| _json["updateTime"] = updateTime; |
| } |
| return _json; |
| } |
| } |
| |
| /// The `Status` type defines a logical error model that is suitable for |
| /// different programming environments, including REST APIs and RPC APIs. It is |
| /// used by [gRPC](https://github.com/grpc). Each `Status` message contains |
| /// three pieces of data: error code, error message, and error details. You can |
| /// find out more about this error model and how to work with it in the [API |
| /// Design Guide](https://cloud.google.com/apis/design/errors). |
| class Status { |
| /// The status code, which should be an enum value of google.rpc.Code. |
| core.int code; |
| |
| /// A list of messages that carry the error details. There is a common set of |
| /// message types for APIs to use. |
| /// |
| /// The values for Object must be JSON objects. It can consist of `num`, |
| /// `String`, `bool` and `null` as well as `Map` and `List` values. |
| core.List<core.Map<core.String, core.Object>> details; |
| |
| /// A developer-facing error message, which should be in English. Any |
| /// user-facing error message should be localized and sent in the |
| /// google.rpc.Status.details field, or localized by the client. |
| core.String message; |
| |
| Status(); |
| |
| Status.fromJson(core.Map _json) { |
| if (_json.containsKey("code")) { |
| code = _json["code"]; |
| } |
| if (_json.containsKey("details")) { |
| details = (_json["details"] as core.List) |
| .map<core.Map<core.String, core.Object>>( |
| (value) => (value as core.Map).cast<core.String, core.Object>()) |
| .toList(); |
| } |
| if (_json.containsKey("message")) { |
| message = _json["message"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (code != null) { |
| _json["code"] = code; |
| } |
| if (details != null) { |
| _json["details"] = details; |
| } |
| if (message != null) { |
| _json["message"] = message; |
| } |
| return _json; |
| } |
| } |
| |
| /// **DEPRECATED**: No data will be returned A brief one-line description of the |
| /// person. |
| class Tagline { |
| /// Metadata about the tagline. |
| FieldMetadata metadata; |
| |
| /// The tagline. |
| core.String value; |
| |
| Tagline(); |
| |
| Tagline.fromJson(core.Map _json) { |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// A request to update an existing user contact group. All updated fields will |
| /// be replaced. |
| class UpdateContactGroupRequest { |
| /// Required. The contact group to update. |
| ContactGroup contactGroup; |
| |
| UpdateContactGroupRequest(); |
| |
| UpdateContactGroupRequest.fromJson(core.Map _json) { |
| if (_json.containsKey("contactGroup")) { |
| contactGroup = new ContactGroup.fromJson(_json["contactGroup"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (contactGroup != null) { |
| _json["contactGroup"] = (contactGroup).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A request to update an existing contact's photo. All requests must have a |
| /// valid photo format: JPEG or PNG. |
| class UpdateContactPhotoRequest { |
| /// Optional. A field mask to restrict which fields on the person are |
| /// returned. Multiple fields can be specified by separating them with commas. |
| /// Defaults to empty if not set, which will skip the post mutate get. Valid |
| /// values are: * addresses * ageRanges * biographies * birthdays * |
| /// calendarUrls * clientData * coverPhotos * emailAddresses * events * |
| /// externalIds * genders * imClients * interests * locales * locations * |
| /// memberships * metadata * miscKeywords * names * nicknames * occupations * |
| /// organizations * phoneNumbers * photos * relations * sipAddresses * skills |
| /// * urls * userDefined |
| core.String personFields; |
| |
| /// Required. Raw photo bytes |
| core.String photoBytes; |
| core.List<core.int> get photoBytesAsBytes { |
| return convert.base64.decode(photoBytes); |
| } |
| |
| set photoBytesAsBytes(core.List<core.int> _bytes) { |
| photoBytes = |
| convert.base64.encode(_bytes).replaceAll("/", "_").replaceAll("+", "-"); |
| } |
| |
| /// Optional. A mask of what source types to return. Defaults to |
| /// ReadSourceType.CONTACT and ReadSourceType.PROFILE if not set. |
| core.List<core.String> sources; |
| |
| UpdateContactPhotoRequest(); |
| |
| UpdateContactPhotoRequest.fromJson(core.Map _json) { |
| if (_json.containsKey("personFields")) { |
| personFields = _json["personFields"]; |
| } |
| if (_json.containsKey("photoBytes")) { |
| photoBytes = _json["photoBytes"]; |
| } |
| if (_json.containsKey("sources")) { |
| sources = (_json["sources"] as core.List).cast<core.String>(); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (personFields != null) { |
| _json["personFields"] = personFields; |
| } |
| if (photoBytes != null) { |
| _json["photoBytes"] = photoBytes; |
| } |
| if (sources != null) { |
| _json["sources"] = sources; |
| } |
| return _json; |
| } |
| } |
| |
| /// The response for updating a contact's photo. |
| class UpdateContactPhotoResponse { |
| /// The updated person, if person_fields is set in the |
| /// UpdateContactPhotoRequest; otherwise this will be unset. |
| Person person; |
| |
| UpdateContactPhotoResponse(); |
| |
| UpdateContactPhotoResponse.fromJson(core.Map _json) { |
| if (_json.containsKey("person")) { |
| person = new Person.fromJson(_json["person"]); |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (person != null) { |
| _json["person"] = (person).toJson(); |
| } |
| return _json; |
| } |
| } |
| |
| /// A person's associated URLs. |
| class Url { |
| /// Output only. The type of the URL translated and formatted in the viewer's |
| /// account locale or the `Accept-Language` HTTP header locale. |
| core.String formattedType; |
| |
| /// Metadata about the URL. |
| FieldMetadata metadata; |
| |
| /// The type of the URL. The type can be custom or one of these predefined |
| /// values: * `home` * `work` * `blog` * `profile` * `homePage` * `ftp` * |
| /// `reservations` * `appInstallPage`: website for a Currents application. * |
| /// `other` |
| core.String type; |
| |
| /// The URL. |
| core.String value; |
| |
| Url(); |
| |
| Url.fromJson(core.Map _json) { |
| if (_json.containsKey("formattedType")) { |
| formattedType = _json["formattedType"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("type")) { |
| type = _json["type"]; |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (formattedType != null) { |
| _json["formattedType"] = formattedType; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (type != null) { |
| _json["type"] = type; |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |
| |
| /// Arbitrary user data that is populated by the end users. |
| class UserDefined { |
| /// The end user specified key of the user defined data. |
| core.String key; |
| |
| /// Metadata about the user defined data. |
| FieldMetadata metadata; |
| |
| /// The end user specified value of the user defined data. |
| core.String value; |
| |
| UserDefined(); |
| |
| UserDefined.fromJson(core.Map _json) { |
| if (_json.containsKey("key")) { |
| key = _json["key"]; |
| } |
| if (_json.containsKey("metadata")) { |
| metadata = new FieldMetadata.fromJson(_json["metadata"]); |
| } |
| if (_json.containsKey("value")) { |
| value = _json["value"]; |
| } |
| } |
| |
| core.Map<core.String, core.Object> toJson() { |
| final core.Map<core.String, core.Object> _json = |
| new core.Map<core.String, core.Object>(); |
| if (key != null) { |
| _json["key"] = key; |
| } |
| if (metadata != null) { |
| _json["metadata"] = (metadata).toJson(); |
| } |
| if (value != null) { |
| _json["value"] = value; |
| } |
| return _json; |
| } |
| } |