diff --git a/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/client.go b/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/client.go new file mode 100644 index 000000000..085b953aa --- /dev/null +++ b/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/client.go @@ -0,0 +1,4730 @@ +// Copyright (c) Dropbox, Inc. +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +// THE SOFTWARE. + +package team + +import ( + "bytes" + "encoding/json" + "io/ioutil" + "log" + "net/http" + + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/async" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/file_properties" +) + +// Client interface describes all routes in this namespace +type Client interface { + // DevicesListMemberDevices : List all device sessions of a team's member. + DevicesListMemberDevices(arg *ListMemberDevicesArg) (res *ListMemberDevicesResult, err error) + // DevicesListMembersDevices : List all device sessions of a team. + DevicesListMembersDevices(arg *ListMembersDevicesArg) (res *ListMembersDevicesResult, err error) + // DevicesListTeamDevices : List all device sessions of a team. + // Deprecated: Use `DevicesListMembersDevices` instead + DevicesListTeamDevices(arg *ListTeamDevicesArg) (res *ListTeamDevicesResult, err error) + // DevicesRevokeDeviceSession : Revoke a device session of a team's member. + DevicesRevokeDeviceSession(arg *RevokeDeviceSessionArg) (err error) + // DevicesRevokeDeviceSessionBatch : Revoke a list of device sessions of + // team members. + DevicesRevokeDeviceSessionBatch(arg *RevokeDeviceSessionBatchArg) (res *RevokeDeviceSessionBatchResult, err error) + // FeaturesGetValues : Get the values for one or more featues. This route + // allows you to check your account's capability for what feature you can + // access or what value you have for certain features. Permission : Team + // information. + FeaturesGetValues(arg *FeaturesGetValuesBatchArg) (res *FeaturesGetValuesBatchResult, err error) + // GetInfo : Retrieves information about a team. + GetInfo() (res *TeamGetInfoResult, err error) + // GroupsCreate : Creates a new, empty group, with a requested name. + // Permission : Team member management. + GroupsCreate(arg *GroupCreateArg) (res *GroupFullInfo, err error) + // GroupsDelete : Deletes a group. The group is deleted immediately. However + // the revoking of group-owned resources may take additional time. Use the + // `groupsJobStatusGet` to determine whether this process has completed. + // Permission : Team member management. + GroupsDelete(arg *GroupSelector) (res *async.LaunchEmptyResult, err error) + // GroupsGetInfo : Retrieves information about one or more groups. Note that + // the optional field `GroupFullInfo.members` is not returned for + // system-managed groups. Permission : Team Information. + GroupsGetInfo(arg *GroupsSelector) (res []*GroupsGetInfoItem, err error) + // GroupsJobStatusGet : Once an async_job_id is returned from + // `groupsDelete`, `groupsMembersAdd` , or `groupsMembersRemove` use this + // method to poll the status of granting/revoking group members' access to + // group-owned resources. Permission : Team member management. + GroupsJobStatusGet(arg *async.PollArg) (res *async.PollEmptyResult, err error) + // GroupsList : Lists groups on a team. Permission : Team Information. + GroupsList(arg *GroupsListArg) (res *GroupsListResult, err error) + // GroupsListContinue : Once a cursor has been retrieved from `groupsList`, + // use this to paginate through all groups. Permission : Team Information. + GroupsListContinue(arg *GroupsListContinueArg) (res *GroupsListResult, err error) + // GroupsMembersAdd : Adds members to a group. The members are added + // immediately. However the granting of group-owned resources may take + // additional time. Use the `groupsJobStatusGet` to determine whether this + // process has completed. Permission : Team member management. + GroupsMembersAdd(arg *GroupMembersAddArg) (res *GroupMembersChangeResult, err error) + // GroupsMembersList : Lists members of a group. Permission : Team + // Information. + GroupsMembersList(arg *GroupsMembersListArg) (res *GroupsMembersListResult, err error) + // GroupsMembersListContinue : Once a cursor has been retrieved from + // `groupsMembersList`, use this to paginate through all members of the + // group. Permission : Team information. + GroupsMembersListContinue(arg *GroupsMembersListContinueArg) (res *GroupsMembersListResult, err error) + // GroupsMembersRemove : Removes members from a group. The members are + // removed immediately. However the revoking of group-owned resources may + // take additional time. Use the `groupsJobStatusGet` to determine whether + // this process has completed. This method permits removing the only owner + // of a group, even in cases where this is not possible via the web client. + // Permission : Team member management. + GroupsMembersRemove(arg *GroupMembersRemoveArg) (res *GroupMembersChangeResult, err error) + // GroupsMembersSetAccessType : Sets a member's access type in a group. + // Permission : Team member management. + GroupsMembersSetAccessType(arg *GroupMembersSetAccessTypeArg) (res []*GroupsGetInfoItem, err error) + // GroupsUpdate : Updates a group's name and/or external ID. Permission : + // Team member management. + GroupsUpdate(arg *GroupUpdateArgs) (res *GroupFullInfo, err error) + // LinkedAppsListMemberLinkedApps : List all linked applications of the team + // member. Note, this endpoint does not list any team-linked applications. + LinkedAppsListMemberLinkedApps(arg *ListMemberAppsArg) (res *ListMemberAppsResult, err error) + // LinkedAppsListMembersLinkedApps : List all applications linked to the + // team members' accounts. Note, this endpoint does not list any team-linked + // applications. + LinkedAppsListMembersLinkedApps(arg *ListMembersAppsArg) (res *ListMembersAppsResult, err error) + // LinkedAppsListTeamLinkedApps : List all applications linked to the team + // members' accounts. Note, this endpoint doesn't list any team-linked + // applications. + // Deprecated: Use `LinkedAppsListMembersLinkedApps` instead + LinkedAppsListTeamLinkedApps(arg *ListTeamAppsArg) (res *ListTeamAppsResult, err error) + // LinkedAppsRevokeLinkedApp : Revoke a linked application of the team + // member. + LinkedAppsRevokeLinkedApp(arg *RevokeLinkedApiAppArg) (err error) + // LinkedAppsRevokeLinkedAppBatch : Revoke a list of linked applications of + // the team members. + LinkedAppsRevokeLinkedAppBatch(arg *RevokeLinkedApiAppBatchArg) (res *RevokeLinkedAppBatchResult, err error) + // MemberSpaceLimitsExcludedUsersAdd : Add users to member space limits + // excluded users list. + MemberSpaceLimitsExcludedUsersAdd(arg *ExcludedUsersUpdateArg) (res *ExcludedUsersUpdateResult, err error) + // MemberSpaceLimitsExcludedUsersList : List member space limits excluded + // users. + MemberSpaceLimitsExcludedUsersList(arg *ExcludedUsersListArg) (res *ExcludedUsersListResult, err error) + // MemberSpaceLimitsExcludedUsersListContinue : Continue listing member + // space limits excluded users. + MemberSpaceLimitsExcludedUsersListContinue(arg *ExcludedUsersListContinueArg) (res *ExcludedUsersListResult, err error) + // MemberSpaceLimitsExcludedUsersRemove : Remove users from member space + // limits excluded users list. + MemberSpaceLimitsExcludedUsersRemove(arg *ExcludedUsersUpdateArg) (res *ExcludedUsersUpdateResult, err error) + // MemberSpaceLimitsGetCustomQuota : Get users custom quota. Returns none as + // the custom quota if none was set. A maximum of 1000 members can be + // specified in a single call. + MemberSpaceLimitsGetCustomQuota(arg *CustomQuotaUsersArg) (res []*CustomQuotaResult, err error) + // MemberSpaceLimitsRemoveCustomQuota : Remove users custom quota. A maximum + // of 1000 members can be specified in a single call. + MemberSpaceLimitsRemoveCustomQuota(arg *CustomQuotaUsersArg) (res []*RemoveCustomQuotaResult, err error) + // MemberSpaceLimitsSetCustomQuota : Set users custom quota. Custom quota + // has to be at least 15GB. A maximum of 1000 members can be specified in a + // single call. + MemberSpaceLimitsSetCustomQuota(arg *SetCustomQuotaArg) (res []*CustomQuotaResult, err error) + // MembersAdd : Adds members to a team. Permission : Team member management + // A maximum of 20 members can be specified in a single call. If no Dropbox + // account exists with the email address specified, a new Dropbox account + // will be created with the given email address, and that account will be + // invited to the team. If a personal Dropbox account exists with the email + // address specified in the call, this call will create a placeholder + // Dropbox account for the user on the team and send an email inviting the + // user to migrate their existing personal account onto the team. Team + // member management apps are required to set an initial given_name and + // surname for a user to use in the team invitation and for 'Perform as team + // member' actions taken on the user before they become 'active'. + MembersAdd(arg *MembersAddArg) (res *MembersAddLaunch, err error) + // MembersAddJobStatusGet : Once an async_job_id is returned from + // `membersAdd` , use this to poll the status of the asynchronous request. + // Permission : Team member management. + MembersAddJobStatusGet(arg *async.PollArg) (res *MembersAddJobStatus, err error) + // MembersGetInfo : Returns information about multiple team members. + // Permission : Team information This endpoint will return + // `MembersGetInfoItem.id_not_found`, for IDs (or emails) that cannot be + // matched to a valid team member. + MembersGetInfo(arg *MembersGetInfoArgs) (res []*MembersGetInfoItem, err error) + // MembersList : Lists members of a team. Permission : Team information. + MembersList(arg *MembersListArg) (res *MembersListResult, err error) + // MembersListContinue : Once a cursor has been retrieved from + // `membersList`, use this to paginate through all team members. Permission + // : Team information. + MembersListContinue(arg *MembersListContinueArg) (res *MembersListResult, err error) + // MembersRecover : Recover a deleted member. Permission : Team member + // management Exactly one of team_member_id, email, or external_id must be + // provided to identify the user account. + MembersRecover(arg *MembersRecoverArg) (err error) + // MembersRemove : Removes a member from a team. Permission : Team member + // management Exactly one of team_member_id, email, or external_id must be + // provided to identify the user account. Accounts can be recovered via + // `membersRecover` for a 7 day period or until the account has been + // permanently deleted or transferred to another account (whichever comes + // first). Calling `membersAdd` while a user is still recoverable on your + // team will return with `MemberAddResult.user_already_on_team`. Accounts + // can have their files transferred via the admin console for a limited + // time, based on the version history length associated with the team (120 + // days for most teams). This endpoint may initiate an asynchronous job. To + // obtain the final result of the job, the client should periodically poll + // `membersRemoveJobStatusGet`. + MembersRemove(arg *MembersRemoveArg) (res *async.LaunchEmptyResult, err error) + // MembersRemoveJobStatusGet : Once an async_job_id is returned from + // `membersRemove` , use this to poll the status of the asynchronous + // request. Permission : Team member management. + MembersRemoveJobStatusGet(arg *async.PollArg) (res *async.PollEmptyResult, err error) + // MembersSendWelcomeEmail : Sends welcome email to pending team member. + // Permission : Team member management Exactly one of team_member_id, email, + // or external_id must be provided to identify the user account. No-op if + // team member is not pending. + MembersSendWelcomeEmail(arg *UserSelectorArg) (err error) + // MembersSetAdminPermissions : Updates a team member's permissions. + // Permission : Team member management. + MembersSetAdminPermissions(arg *MembersSetPermissionsArg) (res *MembersSetPermissionsResult, err error) + // MembersSetProfile : Updates a team member's profile. Permission : Team + // member management. + MembersSetProfile(arg *MembersSetProfileArg) (res *TeamMemberInfo, err error) + // MembersSuspend : Suspend a member from a team. Permission : Team member + // management Exactly one of team_member_id, email, or external_id must be + // provided to identify the user account. + MembersSuspend(arg *MembersDeactivateArg) (err error) + // MembersUnsuspend : Unsuspend a member from a team. Permission : Team + // member management Exactly one of team_member_id, email, or external_id + // must be provided to identify the user account. + MembersUnsuspend(arg *MembersUnsuspendArg) (err error) + // NamespacesList : Returns a list of all team-accessible namespaces. This + // list includes team folders, shared folders containing team members, team + // members' home namespaces, and team members' app folders. Home namespaces + // and app folders are always owned by this team or members of the team, but + // shared folders may be owned by other users or other teams. Duplicates may + // occur in the list. + NamespacesList(arg *TeamNamespacesListArg) (res *TeamNamespacesListResult, err error) + // NamespacesListContinue : Once a cursor has been retrieved from + // `namespacesList`, use this to paginate through all team-accessible + // namespaces. Duplicates may occur in the list. + NamespacesListContinue(arg *TeamNamespacesListContinueArg) (res *TeamNamespacesListResult, err error) + // PropertiesTemplateAdd : has no documentation (yet) + // Deprecated: + PropertiesTemplateAdd(arg *file_properties.AddTemplateArg) (res *file_properties.AddTemplateResult, err error) + // PropertiesTemplateGet : has no documentation (yet) + // Deprecated: + PropertiesTemplateGet(arg *file_properties.GetTemplateArg) (res *file_properties.GetTemplateResult, err error) + // PropertiesTemplateList : has no documentation (yet) + // Deprecated: + PropertiesTemplateList() (res *file_properties.ListTemplateResult, err error) + // PropertiesTemplateUpdate : has no documentation (yet) + // Deprecated: + PropertiesTemplateUpdate(arg *file_properties.UpdateTemplateArg) (res *file_properties.UpdateTemplateResult, err error) + // ReportsGetActivity : Retrieves reporting data about a team's user + // activity. + ReportsGetActivity(arg *DateRange) (res *GetActivityReport, err error) + // ReportsGetDevices : Retrieves reporting data about a team's linked + // devices. + ReportsGetDevices(arg *DateRange) (res *GetDevicesReport, err error) + // ReportsGetMembership : Retrieves reporting data about a team's + // membership. + ReportsGetMembership(arg *DateRange) (res *GetMembershipReport, err error) + // ReportsGetStorage : Retrieves reporting data about a team's storage + // usage. + ReportsGetStorage(arg *DateRange) (res *GetStorageReport, err error) + // TeamFolderActivate : Sets an archived team folder's status to active. + // Permission : Team member file access. + TeamFolderActivate(arg *TeamFolderIdArg) (res *TeamFolderMetadata, err error) + // TeamFolderArchive : Sets an active team folder's status to archived and + // removes all folder and file members. Permission : Team member file + // access. + TeamFolderArchive(arg *TeamFolderArchiveArg) (res *TeamFolderArchiveLaunch, err error) + // TeamFolderArchiveCheck : Returns the status of an asynchronous job for + // archiving a team folder. Permission : Team member file access. + TeamFolderArchiveCheck(arg *async.PollArg) (res *TeamFolderArchiveJobStatus, err error) + // TeamFolderCreate : Creates a new, active, team folder with no members. + // Permission : Team member file access. + TeamFolderCreate(arg *TeamFolderCreateArg) (res *TeamFolderMetadata, err error) + // TeamFolderGetInfo : Retrieves metadata for team folders. Permission : + // Team member file access. + TeamFolderGetInfo(arg *TeamFolderIdListArg) (res []*TeamFolderGetInfoItem, err error) + // TeamFolderList : Lists all team folders. Permission : Team member file + // access. + TeamFolderList(arg *TeamFolderListArg) (res *TeamFolderListResult, err error) + // TeamFolderListContinue : Once a cursor has been retrieved from + // `teamFolderList`, use this to paginate through all team folders. + // Permission : Team member file access. + TeamFolderListContinue(arg *TeamFolderListContinueArg) (res *TeamFolderListResult, err error) + // TeamFolderPermanentlyDelete : Permanently deletes an archived team + // folder. Permission : Team member file access. + TeamFolderPermanentlyDelete(arg *TeamFolderIdArg) (err error) + // TeamFolderRename : Changes an active team folder's name. Permission : + // Team member file access. + TeamFolderRename(arg *TeamFolderRenameArg) (res *TeamFolderMetadata, err error) + // TeamFolderUpdateSyncSettings : Updates the sync settings on a team folder + // or its contents. Use of this endpoint requires that the team has team + // selective sync enabled. + TeamFolderUpdateSyncSettings(arg *TeamFolderUpdateSyncSettingsArg) (res *TeamFolderMetadata, err error) + // TokenGetAuthenticatedAdmin : Returns the member profile of the admin who + // generated the team access token used to make the call. + TokenGetAuthenticatedAdmin() (res *TokenGetAuthenticatedAdminResult, err error) +} + +type apiImpl dropbox.Context + +//DevicesListMemberDevicesAPIError is an error-wrapper for the devices/list_member_devices route +type DevicesListMemberDevicesAPIError struct { + dropbox.APIError + EndpointError *ListMemberDevicesError `json:"error"` +} + +func (dbx *apiImpl) DevicesListMemberDevices(arg *ListMemberDevicesArg) (res *ListMemberDevicesResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "devices/list_member_devices", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError DevicesListMemberDevicesAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//DevicesListMembersDevicesAPIError is an error-wrapper for the devices/list_members_devices route +type DevicesListMembersDevicesAPIError struct { + dropbox.APIError + EndpointError *ListMembersDevicesError `json:"error"` +} + +func (dbx *apiImpl) DevicesListMembersDevices(arg *ListMembersDevicesArg) (res *ListMembersDevicesResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "devices/list_members_devices", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError DevicesListMembersDevicesAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//DevicesListTeamDevicesAPIError is an error-wrapper for the devices/list_team_devices route +type DevicesListTeamDevicesAPIError struct { + dropbox.APIError + EndpointError *ListTeamDevicesError `json:"error"` +} + +func (dbx *apiImpl) DevicesListTeamDevices(arg *ListTeamDevicesArg) (res *ListTeamDevicesResult, err error) { + log.Printf("WARNING: API `DevicesListTeamDevices` is deprecated") + log.Printf("Use API `DevicesListMembersDevices` instead") + + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "devices/list_team_devices", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError DevicesListTeamDevicesAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//DevicesRevokeDeviceSessionAPIError is an error-wrapper for the devices/revoke_device_session route +type DevicesRevokeDeviceSessionAPIError struct { + dropbox.APIError + EndpointError *RevokeDeviceSessionError `json:"error"` +} + +func (dbx *apiImpl) DevicesRevokeDeviceSession(arg *RevokeDeviceSessionArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "devices/revoke_device_session", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError DevicesRevokeDeviceSessionAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//DevicesRevokeDeviceSessionBatchAPIError is an error-wrapper for the devices/revoke_device_session_batch route +type DevicesRevokeDeviceSessionBatchAPIError struct { + dropbox.APIError + EndpointError *RevokeDeviceSessionBatchError `json:"error"` +} + +func (dbx *apiImpl) DevicesRevokeDeviceSessionBatch(arg *RevokeDeviceSessionBatchArg) (res *RevokeDeviceSessionBatchResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "devices/revoke_device_session_batch", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError DevicesRevokeDeviceSessionBatchAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//FeaturesGetValuesAPIError is an error-wrapper for the features/get_values route +type FeaturesGetValuesAPIError struct { + dropbox.APIError + EndpointError *FeaturesGetValuesBatchError `json:"error"` +} + +func (dbx *apiImpl) FeaturesGetValues(arg *FeaturesGetValuesBatchArg) (res *FeaturesGetValuesBatchResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "features/get_values", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError FeaturesGetValuesAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GetInfoAPIError is an error-wrapper for the get_info route +type GetInfoAPIError struct { + dropbox.APIError + EndpointError struct{} `json:"error"` +} + +func (dbx *apiImpl) GetInfo() (res *TeamGetInfoResult, err error) { + cli := dbx.Client + + headers := map[string]string{} + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "get_info", headers, nil) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GetInfoAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsCreateAPIError is an error-wrapper for the groups/create route +type GroupsCreateAPIError struct { + dropbox.APIError + EndpointError *GroupCreateError `json:"error"` +} + +func (dbx *apiImpl) GroupsCreate(arg *GroupCreateArg) (res *GroupFullInfo, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/create", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsCreateAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsDeleteAPIError is an error-wrapper for the groups/delete route +type GroupsDeleteAPIError struct { + dropbox.APIError + EndpointError *GroupDeleteError `json:"error"` +} + +func (dbx *apiImpl) GroupsDelete(arg *GroupSelector) (res *async.LaunchEmptyResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/delete", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsDeleteAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsGetInfoAPIError is an error-wrapper for the groups/get_info route +type GroupsGetInfoAPIError struct { + dropbox.APIError + EndpointError *GroupsGetInfoError `json:"error"` +} + +func (dbx *apiImpl) GroupsGetInfo(arg *GroupsSelector) (res []*GroupsGetInfoItem, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/get_info", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsGetInfoAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsJobStatusGetAPIError is an error-wrapper for the groups/job_status/get route +type GroupsJobStatusGetAPIError struct { + dropbox.APIError + EndpointError *GroupsPollError `json:"error"` +} + +func (dbx *apiImpl) GroupsJobStatusGet(arg *async.PollArg) (res *async.PollEmptyResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/job_status/get", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsJobStatusGetAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsListAPIError is an error-wrapper for the groups/list route +type GroupsListAPIError struct { + dropbox.APIError + EndpointError struct{} `json:"error"` +} + +func (dbx *apiImpl) GroupsList(arg *GroupsListArg) (res *GroupsListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsListContinueAPIError is an error-wrapper for the groups/list/continue route +type GroupsListContinueAPIError struct { + dropbox.APIError + EndpointError *GroupsListContinueError `json:"error"` +} + +func (dbx *apiImpl) GroupsListContinue(arg *GroupsListContinueArg) (res *GroupsListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsMembersAddAPIError is an error-wrapper for the groups/members/add route +type GroupsMembersAddAPIError struct { + dropbox.APIError + EndpointError *GroupMembersAddError `json:"error"` +} + +func (dbx *apiImpl) GroupsMembersAdd(arg *GroupMembersAddArg) (res *GroupMembersChangeResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/members/add", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsMembersAddAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsMembersListAPIError is an error-wrapper for the groups/members/list route +type GroupsMembersListAPIError struct { + dropbox.APIError + EndpointError *GroupSelectorError `json:"error"` +} + +func (dbx *apiImpl) GroupsMembersList(arg *GroupsMembersListArg) (res *GroupsMembersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/members/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsMembersListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsMembersListContinueAPIError is an error-wrapper for the groups/members/list/continue route +type GroupsMembersListContinueAPIError struct { + dropbox.APIError + EndpointError *GroupsMembersListContinueError `json:"error"` +} + +func (dbx *apiImpl) GroupsMembersListContinue(arg *GroupsMembersListContinueArg) (res *GroupsMembersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/members/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsMembersListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsMembersRemoveAPIError is an error-wrapper for the groups/members/remove route +type GroupsMembersRemoveAPIError struct { + dropbox.APIError + EndpointError *GroupMembersRemoveError `json:"error"` +} + +func (dbx *apiImpl) GroupsMembersRemove(arg *GroupMembersRemoveArg) (res *GroupMembersChangeResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/members/remove", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsMembersRemoveAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsMembersSetAccessTypeAPIError is an error-wrapper for the groups/members/set_access_type route +type GroupsMembersSetAccessTypeAPIError struct { + dropbox.APIError + EndpointError *GroupMemberSetAccessTypeError `json:"error"` +} + +func (dbx *apiImpl) GroupsMembersSetAccessType(arg *GroupMembersSetAccessTypeArg) (res []*GroupsGetInfoItem, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/members/set_access_type", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsMembersSetAccessTypeAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//GroupsUpdateAPIError is an error-wrapper for the groups/update route +type GroupsUpdateAPIError struct { + dropbox.APIError + EndpointError *GroupUpdateError `json:"error"` +} + +func (dbx *apiImpl) GroupsUpdate(arg *GroupUpdateArgs) (res *GroupFullInfo, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "groups/update", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError GroupsUpdateAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//LinkedAppsListMemberLinkedAppsAPIError is an error-wrapper for the linked_apps/list_member_linked_apps route +type LinkedAppsListMemberLinkedAppsAPIError struct { + dropbox.APIError + EndpointError *ListMemberAppsError `json:"error"` +} + +func (dbx *apiImpl) LinkedAppsListMemberLinkedApps(arg *ListMemberAppsArg) (res *ListMemberAppsResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "linked_apps/list_member_linked_apps", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError LinkedAppsListMemberLinkedAppsAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//LinkedAppsListMembersLinkedAppsAPIError is an error-wrapper for the linked_apps/list_members_linked_apps route +type LinkedAppsListMembersLinkedAppsAPIError struct { + dropbox.APIError + EndpointError *ListMembersAppsError `json:"error"` +} + +func (dbx *apiImpl) LinkedAppsListMembersLinkedApps(arg *ListMembersAppsArg) (res *ListMembersAppsResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "linked_apps/list_members_linked_apps", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError LinkedAppsListMembersLinkedAppsAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//LinkedAppsListTeamLinkedAppsAPIError is an error-wrapper for the linked_apps/list_team_linked_apps route +type LinkedAppsListTeamLinkedAppsAPIError struct { + dropbox.APIError + EndpointError *ListTeamAppsError `json:"error"` +} + +func (dbx *apiImpl) LinkedAppsListTeamLinkedApps(arg *ListTeamAppsArg) (res *ListTeamAppsResult, err error) { + log.Printf("WARNING: API `LinkedAppsListTeamLinkedApps` is deprecated") + log.Printf("Use API `LinkedAppsListMembersLinkedApps` instead") + + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "linked_apps/list_team_linked_apps", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError LinkedAppsListTeamLinkedAppsAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//LinkedAppsRevokeLinkedAppAPIError is an error-wrapper for the linked_apps/revoke_linked_app route +type LinkedAppsRevokeLinkedAppAPIError struct { + dropbox.APIError + EndpointError *RevokeLinkedAppError `json:"error"` +} + +func (dbx *apiImpl) LinkedAppsRevokeLinkedApp(arg *RevokeLinkedApiAppArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "linked_apps/revoke_linked_app", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError LinkedAppsRevokeLinkedAppAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//LinkedAppsRevokeLinkedAppBatchAPIError is an error-wrapper for the linked_apps/revoke_linked_app_batch route +type LinkedAppsRevokeLinkedAppBatchAPIError struct { + dropbox.APIError + EndpointError *RevokeLinkedAppBatchError `json:"error"` +} + +func (dbx *apiImpl) LinkedAppsRevokeLinkedAppBatch(arg *RevokeLinkedApiAppBatchArg) (res *RevokeLinkedAppBatchResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "linked_apps/revoke_linked_app_batch", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError LinkedAppsRevokeLinkedAppBatchAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsExcludedUsersAddAPIError is an error-wrapper for the member_space_limits/excluded_users/add route +type MemberSpaceLimitsExcludedUsersAddAPIError struct { + dropbox.APIError + EndpointError *ExcludedUsersUpdateError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsExcludedUsersAdd(arg *ExcludedUsersUpdateArg) (res *ExcludedUsersUpdateResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/excluded_users/add", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsExcludedUsersAddAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsExcludedUsersListAPIError is an error-wrapper for the member_space_limits/excluded_users/list route +type MemberSpaceLimitsExcludedUsersListAPIError struct { + dropbox.APIError + EndpointError *ExcludedUsersListError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsExcludedUsersList(arg *ExcludedUsersListArg) (res *ExcludedUsersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/excluded_users/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsExcludedUsersListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsExcludedUsersListContinueAPIError is an error-wrapper for the member_space_limits/excluded_users/list/continue route +type MemberSpaceLimitsExcludedUsersListContinueAPIError struct { + dropbox.APIError + EndpointError *ExcludedUsersListContinueError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsExcludedUsersListContinue(arg *ExcludedUsersListContinueArg) (res *ExcludedUsersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/excluded_users/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsExcludedUsersListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsExcludedUsersRemoveAPIError is an error-wrapper for the member_space_limits/excluded_users/remove route +type MemberSpaceLimitsExcludedUsersRemoveAPIError struct { + dropbox.APIError + EndpointError *ExcludedUsersUpdateError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsExcludedUsersRemove(arg *ExcludedUsersUpdateArg) (res *ExcludedUsersUpdateResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/excluded_users/remove", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsExcludedUsersRemoveAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsGetCustomQuotaAPIError is an error-wrapper for the member_space_limits/get_custom_quota route +type MemberSpaceLimitsGetCustomQuotaAPIError struct { + dropbox.APIError + EndpointError *CustomQuotaError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsGetCustomQuota(arg *CustomQuotaUsersArg) (res []*CustomQuotaResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/get_custom_quota", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsGetCustomQuotaAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsRemoveCustomQuotaAPIError is an error-wrapper for the member_space_limits/remove_custom_quota route +type MemberSpaceLimitsRemoveCustomQuotaAPIError struct { + dropbox.APIError + EndpointError *CustomQuotaError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsRemoveCustomQuota(arg *CustomQuotaUsersArg) (res []*RemoveCustomQuotaResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/remove_custom_quota", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsRemoveCustomQuotaAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MemberSpaceLimitsSetCustomQuotaAPIError is an error-wrapper for the member_space_limits/set_custom_quota route +type MemberSpaceLimitsSetCustomQuotaAPIError struct { + dropbox.APIError + EndpointError *SetCustomQuotaError `json:"error"` +} + +func (dbx *apiImpl) MemberSpaceLimitsSetCustomQuota(arg *SetCustomQuotaArg) (res []*CustomQuotaResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "member_space_limits/set_custom_quota", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MemberSpaceLimitsSetCustomQuotaAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersAddAPIError is an error-wrapper for the members/add route +type MembersAddAPIError struct { + dropbox.APIError + EndpointError struct{} `json:"error"` +} + +func (dbx *apiImpl) MembersAdd(arg *MembersAddArg) (res *MembersAddLaunch, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/add", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersAddAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersAddJobStatusGetAPIError is an error-wrapper for the members/add/job_status/get route +type MembersAddJobStatusGetAPIError struct { + dropbox.APIError + EndpointError *async.PollError `json:"error"` +} + +func (dbx *apiImpl) MembersAddJobStatusGet(arg *async.PollArg) (res *MembersAddJobStatus, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/add/job_status/get", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersAddJobStatusGetAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersGetInfoAPIError is an error-wrapper for the members/get_info route +type MembersGetInfoAPIError struct { + dropbox.APIError + EndpointError *MembersGetInfoError `json:"error"` +} + +func (dbx *apiImpl) MembersGetInfo(arg *MembersGetInfoArgs) (res []*MembersGetInfoItem, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/get_info", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersGetInfoAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersListAPIError is an error-wrapper for the members/list route +type MembersListAPIError struct { + dropbox.APIError + EndpointError *MembersListError `json:"error"` +} + +func (dbx *apiImpl) MembersList(arg *MembersListArg) (res *MembersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersListContinueAPIError is an error-wrapper for the members/list/continue route +type MembersListContinueAPIError struct { + dropbox.APIError + EndpointError *MembersListContinueError `json:"error"` +} + +func (dbx *apiImpl) MembersListContinue(arg *MembersListContinueArg) (res *MembersListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersRecoverAPIError is an error-wrapper for the members/recover route +type MembersRecoverAPIError struct { + dropbox.APIError + EndpointError *MembersRecoverError `json:"error"` +} + +func (dbx *apiImpl) MembersRecover(arg *MembersRecoverArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/recover", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersRecoverAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersRemoveAPIError is an error-wrapper for the members/remove route +type MembersRemoveAPIError struct { + dropbox.APIError + EndpointError *MembersRemoveError `json:"error"` +} + +func (dbx *apiImpl) MembersRemove(arg *MembersRemoveArg) (res *async.LaunchEmptyResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/remove", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersRemoveAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersRemoveJobStatusGetAPIError is an error-wrapper for the members/remove/job_status/get route +type MembersRemoveJobStatusGetAPIError struct { + dropbox.APIError + EndpointError *async.PollError `json:"error"` +} + +func (dbx *apiImpl) MembersRemoveJobStatusGet(arg *async.PollArg) (res *async.PollEmptyResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/remove/job_status/get", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersRemoveJobStatusGetAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersSendWelcomeEmailAPIError is an error-wrapper for the members/send_welcome_email route +type MembersSendWelcomeEmailAPIError struct { + dropbox.APIError + EndpointError *MembersSendWelcomeError `json:"error"` +} + +func (dbx *apiImpl) MembersSendWelcomeEmail(arg *UserSelectorArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/send_welcome_email", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersSendWelcomeEmailAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersSetAdminPermissionsAPIError is an error-wrapper for the members/set_admin_permissions route +type MembersSetAdminPermissionsAPIError struct { + dropbox.APIError + EndpointError *MembersSetPermissionsError `json:"error"` +} + +func (dbx *apiImpl) MembersSetAdminPermissions(arg *MembersSetPermissionsArg) (res *MembersSetPermissionsResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/set_admin_permissions", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersSetAdminPermissionsAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersSetProfileAPIError is an error-wrapper for the members/set_profile route +type MembersSetProfileAPIError struct { + dropbox.APIError + EndpointError *MembersSetProfileError `json:"error"` +} + +func (dbx *apiImpl) MembersSetProfile(arg *MembersSetProfileArg) (res *TeamMemberInfo, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/set_profile", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersSetProfileAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersSuspendAPIError is an error-wrapper for the members/suspend route +type MembersSuspendAPIError struct { + dropbox.APIError + EndpointError *MembersSuspendError `json:"error"` +} + +func (dbx *apiImpl) MembersSuspend(arg *MembersDeactivateArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/suspend", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersSuspendAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//MembersUnsuspendAPIError is an error-wrapper for the members/unsuspend route +type MembersUnsuspendAPIError struct { + dropbox.APIError + EndpointError *MembersUnsuspendError `json:"error"` +} + +func (dbx *apiImpl) MembersUnsuspend(arg *MembersUnsuspendArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "members/unsuspend", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError MembersUnsuspendAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//NamespacesListAPIError is an error-wrapper for the namespaces/list route +type NamespacesListAPIError struct { + dropbox.APIError + EndpointError struct{} `json:"error"` +} + +func (dbx *apiImpl) NamespacesList(arg *TeamNamespacesListArg) (res *TeamNamespacesListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "namespaces/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError NamespacesListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//NamespacesListContinueAPIError is an error-wrapper for the namespaces/list/continue route +type NamespacesListContinueAPIError struct { + dropbox.APIError + EndpointError *TeamNamespacesListContinueError `json:"error"` +} + +func (dbx *apiImpl) NamespacesListContinue(arg *TeamNamespacesListContinueArg) (res *TeamNamespacesListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "namespaces/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError NamespacesListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//PropertiesTemplateAddAPIError is an error-wrapper for the properties/template/add route +type PropertiesTemplateAddAPIError struct { + dropbox.APIError + EndpointError *file_properties.ModifyTemplateError `json:"error"` +} + +func (dbx *apiImpl) PropertiesTemplateAdd(arg *file_properties.AddTemplateArg) (res *file_properties.AddTemplateResult, err error) { + log.Printf("WARNING: API `PropertiesTemplateAdd` is deprecated") + + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "properties/template/add", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError PropertiesTemplateAddAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//PropertiesTemplateGetAPIError is an error-wrapper for the properties/template/get route +type PropertiesTemplateGetAPIError struct { + dropbox.APIError + EndpointError *file_properties.TemplateError `json:"error"` +} + +func (dbx *apiImpl) PropertiesTemplateGet(arg *file_properties.GetTemplateArg) (res *file_properties.GetTemplateResult, err error) { + log.Printf("WARNING: API `PropertiesTemplateGet` is deprecated") + + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "properties/template/get", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError PropertiesTemplateGetAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//PropertiesTemplateListAPIError is an error-wrapper for the properties/template/list route +type PropertiesTemplateListAPIError struct { + dropbox.APIError + EndpointError *file_properties.TemplateError `json:"error"` +} + +func (dbx *apiImpl) PropertiesTemplateList() (res *file_properties.ListTemplateResult, err error) { + log.Printf("WARNING: API `PropertiesTemplateList` is deprecated") + + cli := dbx.Client + + headers := map[string]string{} + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "properties/template/list", headers, nil) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError PropertiesTemplateListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//PropertiesTemplateUpdateAPIError is an error-wrapper for the properties/template/update route +type PropertiesTemplateUpdateAPIError struct { + dropbox.APIError + EndpointError *file_properties.ModifyTemplateError `json:"error"` +} + +func (dbx *apiImpl) PropertiesTemplateUpdate(arg *file_properties.UpdateTemplateArg) (res *file_properties.UpdateTemplateResult, err error) { + log.Printf("WARNING: API `PropertiesTemplateUpdate` is deprecated") + + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "properties/template/update", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError PropertiesTemplateUpdateAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//ReportsGetActivityAPIError is an error-wrapper for the reports/get_activity route +type ReportsGetActivityAPIError struct { + dropbox.APIError + EndpointError *DateRangeError `json:"error"` +} + +func (dbx *apiImpl) ReportsGetActivity(arg *DateRange) (res *GetActivityReport, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "reports/get_activity", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError ReportsGetActivityAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//ReportsGetDevicesAPIError is an error-wrapper for the reports/get_devices route +type ReportsGetDevicesAPIError struct { + dropbox.APIError + EndpointError *DateRangeError `json:"error"` +} + +func (dbx *apiImpl) ReportsGetDevices(arg *DateRange) (res *GetDevicesReport, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "reports/get_devices", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError ReportsGetDevicesAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//ReportsGetMembershipAPIError is an error-wrapper for the reports/get_membership route +type ReportsGetMembershipAPIError struct { + dropbox.APIError + EndpointError *DateRangeError `json:"error"` +} + +func (dbx *apiImpl) ReportsGetMembership(arg *DateRange) (res *GetMembershipReport, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "reports/get_membership", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError ReportsGetMembershipAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//ReportsGetStorageAPIError is an error-wrapper for the reports/get_storage route +type ReportsGetStorageAPIError struct { + dropbox.APIError + EndpointError *DateRangeError `json:"error"` +} + +func (dbx *apiImpl) ReportsGetStorage(arg *DateRange) (res *GetStorageReport, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "reports/get_storage", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError ReportsGetStorageAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderActivateAPIError is an error-wrapper for the team_folder/activate route +type TeamFolderActivateAPIError struct { + dropbox.APIError + EndpointError *TeamFolderActivateError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderActivate(arg *TeamFolderIdArg) (res *TeamFolderMetadata, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/activate", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderActivateAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderArchiveAPIError is an error-wrapper for the team_folder/archive route +type TeamFolderArchiveAPIError struct { + dropbox.APIError + EndpointError *TeamFolderArchiveError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderArchive(arg *TeamFolderArchiveArg) (res *TeamFolderArchiveLaunch, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/archive", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderArchiveAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderArchiveCheckAPIError is an error-wrapper for the team_folder/archive/check route +type TeamFolderArchiveCheckAPIError struct { + dropbox.APIError + EndpointError *async.PollError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderArchiveCheck(arg *async.PollArg) (res *TeamFolderArchiveJobStatus, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/archive/check", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderArchiveCheckAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderCreateAPIError is an error-wrapper for the team_folder/create route +type TeamFolderCreateAPIError struct { + dropbox.APIError + EndpointError *TeamFolderCreateError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderCreate(arg *TeamFolderCreateArg) (res *TeamFolderMetadata, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/create", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderCreateAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderGetInfoAPIError is an error-wrapper for the team_folder/get_info route +type TeamFolderGetInfoAPIError struct { + dropbox.APIError + EndpointError struct{} `json:"error"` +} + +func (dbx *apiImpl) TeamFolderGetInfo(arg *TeamFolderIdListArg) (res []*TeamFolderGetInfoItem, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/get_info", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderGetInfoAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderListAPIError is an error-wrapper for the team_folder/list route +type TeamFolderListAPIError struct { + dropbox.APIError + EndpointError *TeamFolderListError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderList(arg *TeamFolderListArg) (res *TeamFolderListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/list", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderListAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderListContinueAPIError is an error-wrapper for the team_folder/list/continue route +type TeamFolderListContinueAPIError struct { + dropbox.APIError + EndpointError *TeamFolderListContinueError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderListContinue(arg *TeamFolderListContinueArg) (res *TeamFolderListResult, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/list/continue", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderListContinueAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderPermanentlyDeleteAPIError is an error-wrapper for the team_folder/permanently_delete route +type TeamFolderPermanentlyDeleteAPIError struct { + dropbox.APIError + EndpointError *TeamFolderPermanentlyDeleteError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderPermanentlyDelete(arg *TeamFolderIdArg) (err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/permanently_delete", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderPermanentlyDeleteAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderRenameAPIError is an error-wrapper for the team_folder/rename route +type TeamFolderRenameAPIError struct { + dropbox.APIError + EndpointError *TeamFolderRenameError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderRename(arg *TeamFolderRenameArg) (res *TeamFolderMetadata, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/rename", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderRenameAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TeamFolderUpdateSyncSettingsAPIError is an error-wrapper for the team_folder/update_sync_settings route +type TeamFolderUpdateSyncSettingsAPIError struct { + dropbox.APIError + EndpointError *TeamFolderUpdateSyncSettingsError `json:"error"` +} + +func (dbx *apiImpl) TeamFolderUpdateSyncSettings(arg *TeamFolderUpdateSyncSettingsArg) (res *TeamFolderMetadata, err error) { + cli := dbx.Client + + dbx.Config.LogDebug("arg: %v", arg) + b, err := json.Marshal(arg) + if err != nil { + return + } + + headers := map[string]string{ + "Content-Type": "application/json", + } + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "team_folder/update_sync_settings", headers, bytes.NewReader(b)) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TeamFolderUpdateSyncSettingsAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +//TokenGetAuthenticatedAdminAPIError is an error-wrapper for the token/get_authenticated_admin route +type TokenGetAuthenticatedAdminAPIError struct { + dropbox.APIError + EndpointError *TokenGetAuthenticatedAdminError `json:"error"` +} + +func (dbx *apiImpl) TokenGetAuthenticatedAdmin() (res *TokenGetAuthenticatedAdminResult, err error) { + cli := dbx.Client + + headers := map[string]string{} + + req, err := (*dropbox.Context)(dbx).NewRequest("api", "rpc", true, "team", "token/get_authenticated_admin", headers, nil) + if err != nil { + return + } + dbx.Config.LogInfo("req: %v", req) + + resp, err := cli.Do(req) + if err != nil { + return + } + + dbx.Config.LogInfo("resp: %v", resp) + defer resp.Body.Close() + body, err := ioutil.ReadAll(resp.Body) + if err != nil { + return + } + + dbx.Config.LogDebug("body: %v", body) + if resp.StatusCode == http.StatusOK { + err = json.Unmarshal(body, &res) + if err != nil { + return + } + + return + } + if resp.StatusCode == http.StatusConflict { + var apiError TokenGetAuthenticatedAdminAPIError + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return + } + var apiError dropbox.APIError + if resp.StatusCode == http.StatusBadRequest || resp.StatusCode == http.StatusInternalServerError { + apiError.ErrorSummary = string(body) + err = apiError + return + } + err = json.Unmarshal(body, &apiError) + if err != nil { + return + } + err = apiError + return +} + +// New returns a Client implementation for this namespace +func New(c dropbox.Config) Client { + ctx := apiImpl(dropbox.NewContext(c)) + return &ctx +} diff --git a/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/types.go b/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/types.go new file mode 100644 index 000000000..2160d404f --- /dev/null +++ b/vendor/github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team/types.go @@ -0,0 +1,4242 @@ +// Copyright (c) Dropbox, Inc. +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to deal +// in the Software without restriction, including without limitation the rights +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +// copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +// THE SOFTWARE. + +// Package team : has no documentation (yet) +package team + +import ( + "encoding/json" + "time" + + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/files" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team_common" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team_policies" + "github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/users" +) + +// DeviceSession : has no documentation (yet) +type DeviceSession struct { + // SessionId : The session id. + SessionId string `json:"session_id"` + // IpAddress : The IP address of the last activity from this session. + IpAddress string `json:"ip_address,omitempty"` + // Country : The country from which the last activity from this session was + // made. + Country string `json:"country,omitempty"` + // Created : The time this session was created. + Created time.Time `json:"created,omitempty"` + // Updated : The time of the last activity from this session. + Updated time.Time `json:"updated,omitempty"` +} + +// NewDeviceSession returns a new DeviceSession instance +func NewDeviceSession(SessionId string) *DeviceSession { + s := new(DeviceSession) + s.SessionId = SessionId + return s +} + +// ActiveWebSession : Information on active web sessions. +type ActiveWebSession struct { + DeviceSession + // UserAgent : Information on the hosting device. + UserAgent string `json:"user_agent"` + // Os : Information on the hosting operating system. + Os string `json:"os"` + // Browser : Information on the browser used for this web session. + Browser string `json:"browser"` + // Expires : The time this session expires. + Expires time.Time `json:"expires,omitempty"` +} + +// NewActiveWebSession returns a new ActiveWebSession instance +func NewActiveWebSession(SessionId string, UserAgent string, Os string, Browser string) *ActiveWebSession { + s := new(ActiveWebSession) + s.SessionId = SessionId + s.UserAgent = UserAgent + s.Os = Os + s.Browser = Browser + return s +} + +// AdminTier : Describes which team-related admin permissions a user has. +type AdminTier struct { + dropbox.Tagged +} + +// Valid tag values for AdminTier +const ( + AdminTierTeamAdmin = "team_admin" + AdminTierUserManagementAdmin = "user_management_admin" + AdminTierSupportAdmin = "support_admin" + AdminTierMemberOnly = "member_only" +) + +// ApiApp : Information on linked third party applications. +type ApiApp struct { + // AppId : The application unique id. + AppId string `json:"app_id"` + // AppName : The application name. + AppName string `json:"app_name"` + // Publisher : The application publisher name. + Publisher string `json:"publisher,omitempty"` + // PublisherUrl : The publisher's URL. + PublisherUrl string `json:"publisher_url,omitempty"` + // Linked : The time this application was linked. + Linked time.Time `json:"linked,omitempty"` + // IsAppFolder : Whether the linked application uses a dedicated folder. + IsAppFolder bool `json:"is_app_folder"` +} + +// NewApiApp returns a new ApiApp instance +func NewApiApp(AppId string, AppName string, IsAppFolder bool) *ApiApp { + s := new(ApiApp) + s.AppId = AppId + s.AppName = AppName + s.IsAppFolder = IsAppFolder + return s +} + +// BaseDfbReport : Base report structure. +type BaseDfbReport struct { + // StartDate : First date present in the results as 'YYYY-MM-DD' or None. + StartDate string `json:"start_date"` +} + +// NewBaseDfbReport returns a new BaseDfbReport instance +func NewBaseDfbReport(StartDate string) *BaseDfbReport { + s := new(BaseDfbReport) + s.StartDate = StartDate + return s +} + +// BaseTeamFolderError : Base error that all errors for existing team folders +// should extend. +type BaseTeamFolderError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` +} + +// Valid tag values for BaseTeamFolderError +const ( + BaseTeamFolderErrorAccessError = "access_error" + BaseTeamFolderErrorStatusError = "status_error" + BaseTeamFolderErrorTeamSharedDropboxError = "team_shared_dropbox_error" + BaseTeamFolderErrorOther = "other" +) + +// UnmarshalJSON deserializes into a BaseTeamFolderError instance +func (u *BaseTeamFolderError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + } + return nil +} + +// CustomQuotaError : Error returned when getting member custom quota. +type CustomQuotaError struct { + dropbox.Tagged +} + +// Valid tag values for CustomQuotaError +const ( + CustomQuotaErrorTooManyUsers = "too_many_users" + CustomQuotaErrorOther = "other" +) + +// CustomQuotaResult : User custom quota. +type CustomQuotaResult struct { + dropbox.Tagged + // Success : User's custom quota. + Success *UserCustomQuotaResult `json:"success,omitempty"` + // InvalidUser : Invalid user (not in team). + InvalidUser *UserSelectorArg `json:"invalid_user,omitempty"` +} + +// Valid tag values for CustomQuotaResult +const ( + CustomQuotaResultSuccess = "success" + CustomQuotaResultInvalidUser = "invalid_user" + CustomQuotaResultOther = "other" +) + +// UnmarshalJSON deserializes into a CustomQuotaResult instance +func (u *CustomQuotaResult) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Success : User's custom quota. + Success json.RawMessage `json:"success,omitempty"` + // InvalidUser : Invalid user (not in team). + InvalidUser json.RawMessage `json:"invalid_user,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "success": + err = json.Unmarshal(body, &u.Success) + + if err != nil { + return err + } + case "invalid_user": + err = json.Unmarshal(w.InvalidUser, &u.InvalidUser) + + if err != nil { + return err + } + } + return nil +} + +// CustomQuotaUsersArg : has no documentation (yet) +type CustomQuotaUsersArg struct { + // Users : List of users. + Users []*UserSelectorArg `json:"users"` +} + +// NewCustomQuotaUsersArg returns a new CustomQuotaUsersArg instance +func NewCustomQuotaUsersArg(Users []*UserSelectorArg) *CustomQuotaUsersArg { + s := new(CustomQuotaUsersArg) + s.Users = Users + return s +} + +// DateRange : Input arguments that can be provided for most reports. +type DateRange struct { + // StartDate : Optional starting date (inclusive). + StartDate time.Time `json:"start_date,omitempty"` + // EndDate : Optional ending date (exclusive). + EndDate time.Time `json:"end_date,omitempty"` +} + +// NewDateRange returns a new DateRange instance +func NewDateRange() *DateRange { + s := new(DateRange) + return s +} + +// DateRangeError : Errors that can originate from problems in input arguments +// to reports. +type DateRangeError struct { + dropbox.Tagged +} + +// Valid tag values for DateRangeError +const ( + DateRangeErrorOther = "other" +) + +// DesktopClientSession : Information about linked Dropbox desktop client +// sessions. +type DesktopClientSession struct { + DeviceSession + // HostName : Name of the hosting desktop. + HostName string `json:"host_name"` + // ClientType : The Dropbox desktop client type. + ClientType *DesktopPlatform `json:"client_type"` + // ClientVersion : The Dropbox client version. + ClientVersion string `json:"client_version"` + // Platform : Information on the hosting platform. + Platform string `json:"platform"` + // IsDeleteOnUnlinkSupported : Whether it's possible to delete all of the + // account files upon unlinking. + IsDeleteOnUnlinkSupported bool `json:"is_delete_on_unlink_supported"` +} + +// NewDesktopClientSession returns a new DesktopClientSession instance +func NewDesktopClientSession(SessionId string, HostName string, ClientType *DesktopPlatform, ClientVersion string, Platform string, IsDeleteOnUnlinkSupported bool) *DesktopClientSession { + s := new(DesktopClientSession) + s.SessionId = SessionId + s.HostName = HostName + s.ClientType = ClientType + s.ClientVersion = ClientVersion + s.Platform = Platform + s.IsDeleteOnUnlinkSupported = IsDeleteOnUnlinkSupported + return s +} + +// DesktopPlatform : has no documentation (yet) +type DesktopPlatform struct { + dropbox.Tagged +} + +// Valid tag values for DesktopPlatform +const ( + DesktopPlatformWindows = "windows" + DesktopPlatformMac = "mac" + DesktopPlatformLinux = "linux" + DesktopPlatformOther = "other" +) + +// DeviceSessionArg : has no documentation (yet) +type DeviceSessionArg struct { + // SessionId : The session id. + SessionId string `json:"session_id"` + // TeamMemberId : The unique id of the member owning the device. + TeamMemberId string `json:"team_member_id"` +} + +// NewDeviceSessionArg returns a new DeviceSessionArg instance +func NewDeviceSessionArg(SessionId string, TeamMemberId string) *DeviceSessionArg { + s := new(DeviceSessionArg) + s.SessionId = SessionId + s.TeamMemberId = TeamMemberId + return s +} + +// DevicesActive : Each of the items is an array of values, one value per day. +// The value is the number of devices active within a time window, ending with +// that day. If there is no data for a day, then the value will be None. +type DevicesActive struct { + // Windows : Array of number of linked windows (desktop) clients with + // activity. + Windows []uint64 `json:"windows"` + // Macos : Array of number of linked mac (desktop) clients with activity. + Macos []uint64 `json:"macos"` + // Linux : Array of number of linked linus (desktop) clients with activity. + Linux []uint64 `json:"linux"` + // Ios : Array of number of linked ios devices with activity. + Ios []uint64 `json:"ios"` + // Android : Array of number of linked android devices with activity. + Android []uint64 `json:"android"` + // Other : Array of number of other linked devices (blackberry, windows + // phone, etc) with activity. + Other []uint64 `json:"other"` + // Total : Array of total number of linked clients with activity. + Total []uint64 `json:"total"` +} + +// NewDevicesActive returns a new DevicesActive instance +func NewDevicesActive(Windows []uint64, Macos []uint64, Linux []uint64, Ios []uint64, Android []uint64, Other []uint64, Total []uint64) *DevicesActive { + s := new(DevicesActive) + s.Windows = Windows + s.Macos = Macos + s.Linux = Linux + s.Ios = Ios + s.Android = Android + s.Other = Other + s.Total = Total + return s +} + +// ExcludedUsersListArg : Excluded users list argument. +type ExcludedUsersListArg struct { + // Limit : Number of results to return per call. + Limit uint32 `json:"limit"` +} + +// NewExcludedUsersListArg returns a new ExcludedUsersListArg instance +func NewExcludedUsersListArg() *ExcludedUsersListArg { + s := new(ExcludedUsersListArg) + s.Limit = 1000 + return s +} + +// ExcludedUsersListContinueArg : Excluded users list continue argument. +type ExcludedUsersListContinueArg struct { + // Cursor : Indicates from what point to get the next set of users. + Cursor string `json:"cursor"` +} + +// NewExcludedUsersListContinueArg returns a new ExcludedUsersListContinueArg instance +func NewExcludedUsersListContinueArg(Cursor string) *ExcludedUsersListContinueArg { + s := new(ExcludedUsersListContinueArg) + s.Cursor = Cursor + return s +} + +// ExcludedUsersListContinueError : Excluded users list continue error. +type ExcludedUsersListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for ExcludedUsersListContinueError +const ( + ExcludedUsersListContinueErrorInvalidCursor = "invalid_cursor" + ExcludedUsersListContinueErrorOther = "other" +) + +// ExcludedUsersListError : Excluded users list error. +type ExcludedUsersListError struct { + dropbox.Tagged +} + +// Valid tag values for ExcludedUsersListError +const ( + ExcludedUsersListErrorListError = "list_error" + ExcludedUsersListErrorOther = "other" +) + +// ExcludedUsersListResult : Excluded users list result. +type ExcludedUsersListResult struct { + // Users : has no documentation (yet) + Users []*MemberProfile `json:"users"` + // Cursor : Pass the cursor into + // `memberSpaceLimitsExcludedUsersListContinue` to obtain additional + // excluded users. + Cursor string `json:"cursor,omitempty"` + // HasMore : Is true if there are additional excluded users that have not + // been returned yet. An additional call to + // `memberSpaceLimitsExcludedUsersListContinue` can retrieve them. + HasMore bool `json:"has_more"` +} + +// NewExcludedUsersListResult returns a new ExcludedUsersListResult instance +func NewExcludedUsersListResult(Users []*MemberProfile, HasMore bool) *ExcludedUsersListResult { + s := new(ExcludedUsersListResult) + s.Users = Users + s.HasMore = HasMore + return s +} + +// ExcludedUsersUpdateArg : Argument of excluded users update operation. Should +// include a list of users to add/remove (according to endpoint), Maximum size +// of the list is 1000 users. +type ExcludedUsersUpdateArg struct { + // Users : List of users to be added/removed. + Users []*UserSelectorArg `json:"users,omitempty"` +} + +// NewExcludedUsersUpdateArg returns a new ExcludedUsersUpdateArg instance +func NewExcludedUsersUpdateArg() *ExcludedUsersUpdateArg { + s := new(ExcludedUsersUpdateArg) + return s +} + +// ExcludedUsersUpdateError : Excluded users update error. +type ExcludedUsersUpdateError struct { + dropbox.Tagged +} + +// Valid tag values for ExcludedUsersUpdateError +const ( + ExcludedUsersUpdateErrorUsersNotInTeam = "users_not_in_team" + ExcludedUsersUpdateErrorTooManyUsers = "too_many_users" + ExcludedUsersUpdateErrorOther = "other" +) + +// ExcludedUsersUpdateResult : Excluded users update result. +type ExcludedUsersUpdateResult struct { + // Status : Update status. + Status *ExcludedUsersUpdateStatus `json:"status"` +} + +// NewExcludedUsersUpdateResult returns a new ExcludedUsersUpdateResult instance +func NewExcludedUsersUpdateResult(Status *ExcludedUsersUpdateStatus) *ExcludedUsersUpdateResult { + s := new(ExcludedUsersUpdateResult) + s.Status = Status + return s +} + +// ExcludedUsersUpdateStatus : Excluded users update operation status. +type ExcludedUsersUpdateStatus struct { + dropbox.Tagged +} + +// Valid tag values for ExcludedUsersUpdateStatus +const ( + ExcludedUsersUpdateStatusSuccess = "success" + ExcludedUsersUpdateStatusOther = "other" +) + +// Feature : A set of features that a Dropbox Business account may support. +type Feature struct { + dropbox.Tagged +} + +// Valid tag values for Feature +const ( + FeatureUploadApiRateLimit = "upload_api_rate_limit" + FeatureHasTeamSharedDropbox = "has_team_shared_dropbox" + FeatureHasTeamFileEvents = "has_team_file_events" + FeatureHasTeamSelectiveSync = "has_team_selective_sync" + FeatureOther = "other" +) + +// FeatureValue : The values correspond to entries in `Feature`. You may get +// different value according to your Dropbox Business plan. +type FeatureValue struct { + dropbox.Tagged + // UploadApiRateLimit : has no documentation (yet) + UploadApiRateLimit *UploadApiRateLimitValue `json:"upload_api_rate_limit,omitempty"` + // HasTeamSharedDropbox : has no documentation (yet) + HasTeamSharedDropbox *HasTeamSharedDropboxValue `json:"has_team_shared_dropbox,omitempty"` + // HasTeamFileEvents : has no documentation (yet) + HasTeamFileEvents *HasTeamFileEventsValue `json:"has_team_file_events,omitempty"` + // HasTeamSelectiveSync : has no documentation (yet) + HasTeamSelectiveSync *HasTeamSelectiveSyncValue `json:"has_team_selective_sync,omitempty"` +} + +// Valid tag values for FeatureValue +const ( + FeatureValueUploadApiRateLimit = "upload_api_rate_limit" + FeatureValueHasTeamSharedDropbox = "has_team_shared_dropbox" + FeatureValueHasTeamFileEvents = "has_team_file_events" + FeatureValueHasTeamSelectiveSync = "has_team_selective_sync" + FeatureValueOther = "other" +) + +// UnmarshalJSON deserializes into a FeatureValue instance +func (u *FeatureValue) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // UploadApiRateLimit : has no documentation (yet) + UploadApiRateLimit json.RawMessage `json:"upload_api_rate_limit,omitempty"` + // HasTeamSharedDropbox : has no documentation (yet) + HasTeamSharedDropbox json.RawMessage `json:"has_team_shared_dropbox,omitempty"` + // HasTeamFileEvents : has no documentation (yet) + HasTeamFileEvents json.RawMessage `json:"has_team_file_events,omitempty"` + // HasTeamSelectiveSync : has no documentation (yet) + HasTeamSelectiveSync json.RawMessage `json:"has_team_selective_sync,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "upload_api_rate_limit": + err = json.Unmarshal(w.UploadApiRateLimit, &u.UploadApiRateLimit) + + if err != nil { + return err + } + case "has_team_shared_dropbox": + err = json.Unmarshal(w.HasTeamSharedDropbox, &u.HasTeamSharedDropbox) + + if err != nil { + return err + } + case "has_team_file_events": + err = json.Unmarshal(w.HasTeamFileEvents, &u.HasTeamFileEvents) + + if err != nil { + return err + } + case "has_team_selective_sync": + err = json.Unmarshal(w.HasTeamSelectiveSync, &u.HasTeamSelectiveSync) + + if err != nil { + return err + } + } + return nil +} + +// FeaturesGetValuesBatchArg : has no documentation (yet) +type FeaturesGetValuesBatchArg struct { + // Features : A list of features in `Feature`. If the list is empty, this + // route will return `FeaturesGetValuesBatchError`. + Features []*Feature `json:"features"` +} + +// NewFeaturesGetValuesBatchArg returns a new FeaturesGetValuesBatchArg instance +func NewFeaturesGetValuesBatchArg(Features []*Feature) *FeaturesGetValuesBatchArg { + s := new(FeaturesGetValuesBatchArg) + s.Features = Features + return s +} + +// FeaturesGetValuesBatchError : has no documentation (yet) +type FeaturesGetValuesBatchError struct { + dropbox.Tagged +} + +// Valid tag values for FeaturesGetValuesBatchError +const ( + FeaturesGetValuesBatchErrorEmptyFeaturesList = "empty_features_list" + FeaturesGetValuesBatchErrorOther = "other" +) + +// FeaturesGetValuesBatchResult : has no documentation (yet) +type FeaturesGetValuesBatchResult struct { + // Values : has no documentation (yet) + Values []*FeatureValue `json:"values"` +} + +// NewFeaturesGetValuesBatchResult returns a new FeaturesGetValuesBatchResult instance +func NewFeaturesGetValuesBatchResult(Values []*FeatureValue) *FeaturesGetValuesBatchResult { + s := new(FeaturesGetValuesBatchResult) + s.Values = Values + return s +} + +// GetActivityReport : Activity Report Result. Each of the items in the storage +// report is an array of values, one value per day. If there is no data for a +// day, then the value will be None. +type GetActivityReport struct { + BaseDfbReport + // Adds : Array of total number of adds by team members. + Adds []uint64 `json:"adds"` + // Edits : Array of number of edits by team members. If the same user edits + // the same file multiple times this is counted as a single edit. + Edits []uint64 `json:"edits"` + // Deletes : Array of total number of deletes by team members. + Deletes []uint64 `json:"deletes"` + // ActiveUsers28Day : Array of the number of users who have been active in + // the last 28 days. + ActiveUsers28Day []uint64 `json:"active_users_28_day"` + // ActiveUsers7Day : Array of the number of users who have been active in + // the last week. + ActiveUsers7Day []uint64 `json:"active_users_7_day"` + // ActiveUsers1Day : Array of the number of users who have been active in + // the last day. + ActiveUsers1Day []uint64 `json:"active_users_1_day"` + // ActiveSharedFolders28Day : Array of the number of shared folders with + // some activity in the last 28 days. + ActiveSharedFolders28Day []uint64 `json:"active_shared_folders_28_day"` + // ActiveSharedFolders7Day : Array of the number of shared folders with some + // activity in the last week. + ActiveSharedFolders7Day []uint64 `json:"active_shared_folders_7_day"` + // ActiveSharedFolders1Day : Array of the number of shared folders with some + // activity in the last day. + ActiveSharedFolders1Day []uint64 `json:"active_shared_folders_1_day"` + // SharedLinksCreated : Array of the number of shared links created. + SharedLinksCreated []uint64 `json:"shared_links_created"` + // SharedLinksViewedByTeam : Array of the number of views by team users to + // shared links created by the team. + SharedLinksViewedByTeam []uint64 `json:"shared_links_viewed_by_team"` + // SharedLinksViewedByOutsideUser : Array of the number of views by users + // outside of the team to shared links created by the team. + SharedLinksViewedByOutsideUser []uint64 `json:"shared_links_viewed_by_outside_user"` + // SharedLinksViewedByNotLoggedIn : Array of the number of views by + // non-logged-in users to shared links created by the team. + SharedLinksViewedByNotLoggedIn []uint64 `json:"shared_links_viewed_by_not_logged_in"` + // SharedLinksViewedTotal : Array of the total number of views to shared + // links created by the team. + SharedLinksViewedTotal []uint64 `json:"shared_links_viewed_total"` +} + +// NewGetActivityReport returns a new GetActivityReport instance +func NewGetActivityReport(StartDate string, Adds []uint64, Edits []uint64, Deletes []uint64, ActiveUsers28Day []uint64, ActiveUsers7Day []uint64, ActiveUsers1Day []uint64, ActiveSharedFolders28Day []uint64, ActiveSharedFolders7Day []uint64, ActiveSharedFolders1Day []uint64, SharedLinksCreated []uint64, SharedLinksViewedByTeam []uint64, SharedLinksViewedByOutsideUser []uint64, SharedLinksViewedByNotLoggedIn []uint64, SharedLinksViewedTotal []uint64) *GetActivityReport { + s := new(GetActivityReport) + s.StartDate = StartDate + s.Adds = Adds + s.Edits = Edits + s.Deletes = Deletes + s.ActiveUsers28Day = ActiveUsers28Day + s.ActiveUsers7Day = ActiveUsers7Day + s.ActiveUsers1Day = ActiveUsers1Day + s.ActiveSharedFolders28Day = ActiveSharedFolders28Day + s.ActiveSharedFolders7Day = ActiveSharedFolders7Day + s.ActiveSharedFolders1Day = ActiveSharedFolders1Day + s.SharedLinksCreated = SharedLinksCreated + s.SharedLinksViewedByTeam = SharedLinksViewedByTeam + s.SharedLinksViewedByOutsideUser = SharedLinksViewedByOutsideUser + s.SharedLinksViewedByNotLoggedIn = SharedLinksViewedByNotLoggedIn + s.SharedLinksViewedTotal = SharedLinksViewedTotal + return s +} + +// GetDevicesReport : Devices Report Result. Contains subsections for different +// time ranges of activity. Each of the items in each subsection of the storage +// report is an array of values, one value per day. If there is no data for a +// day, then the value will be None. +type GetDevicesReport struct { + BaseDfbReport + // Active1Day : Report of the number of devices active in the last day. + Active1Day *DevicesActive `json:"active_1_day"` + // Active7Day : Report of the number of devices active in the last 7 days. + Active7Day *DevicesActive `json:"active_7_day"` + // Active28Day : Report of the number of devices active in the last 28 days. + Active28Day *DevicesActive `json:"active_28_day"` +} + +// NewGetDevicesReport returns a new GetDevicesReport instance +func NewGetDevicesReport(StartDate string, Active1Day *DevicesActive, Active7Day *DevicesActive, Active28Day *DevicesActive) *GetDevicesReport { + s := new(GetDevicesReport) + s.StartDate = StartDate + s.Active1Day = Active1Day + s.Active7Day = Active7Day + s.Active28Day = Active28Day + return s +} + +// GetMembershipReport : Membership Report Result. Each of the items in the +// storage report is an array of values, one value per day. If there is no data +// for a day, then the value will be None. +type GetMembershipReport struct { + BaseDfbReport + // TeamSize : Team size, for each day. + TeamSize []uint64 `json:"team_size"` + // PendingInvites : The number of pending invites to the team, for each day. + PendingInvites []uint64 `json:"pending_invites"` + // MembersJoined : The number of members that joined the team, for each day. + MembersJoined []uint64 `json:"members_joined"` + // SuspendedMembers : The number of suspended team members, for each day. + SuspendedMembers []uint64 `json:"suspended_members"` + // Licenses : The total number of licenses the team has, for each day. + Licenses []uint64 `json:"licenses"` +} + +// NewGetMembershipReport returns a new GetMembershipReport instance +func NewGetMembershipReport(StartDate string, TeamSize []uint64, PendingInvites []uint64, MembersJoined []uint64, SuspendedMembers []uint64, Licenses []uint64) *GetMembershipReport { + s := new(GetMembershipReport) + s.StartDate = StartDate + s.TeamSize = TeamSize + s.PendingInvites = PendingInvites + s.MembersJoined = MembersJoined + s.SuspendedMembers = SuspendedMembers + s.Licenses = Licenses + return s +} + +// GetStorageReport : Storage Report Result. Each of the items in the storage +// report is an array of values, one value per day. If there is no data for a +// day, then the value will be None. +type GetStorageReport struct { + BaseDfbReport + // TotalUsage : Sum of the shared, unshared, and datastore usages, for each + // day. + TotalUsage []uint64 `json:"total_usage"` + // SharedUsage : Array of the combined size (bytes) of team members' shared + // folders, for each day. + SharedUsage []uint64 `json:"shared_usage"` + // UnsharedUsage : Array of the combined size (bytes) of team members' root + // namespaces, for each day. + UnsharedUsage []uint64 `json:"unshared_usage"` + // SharedFolders : Array of the number of shared folders owned by team + // members, for each day. + SharedFolders []uint64 `json:"shared_folders"` + // MemberStorageMap : Array of storage summaries of team members' account + // sizes. Each storage summary is an array of key, value pairs, where each + // pair describes a storage bucket. The key indicates the upper bound of the + // bucket and the value is the number of users in that bucket. There is one + // such summary per day. If there is no data for a day, the storage summary + // will be empty. + MemberStorageMap [][]*StorageBucket `json:"member_storage_map"` +} + +// NewGetStorageReport returns a new GetStorageReport instance +func NewGetStorageReport(StartDate string, TotalUsage []uint64, SharedUsage []uint64, UnsharedUsage []uint64, SharedFolders []uint64, MemberStorageMap [][]*StorageBucket) *GetStorageReport { + s := new(GetStorageReport) + s.StartDate = StartDate + s.TotalUsage = TotalUsage + s.SharedUsage = SharedUsage + s.UnsharedUsage = UnsharedUsage + s.SharedFolders = SharedFolders + s.MemberStorageMap = MemberStorageMap + return s +} + +// GroupAccessType : Role of a user in group. +type GroupAccessType struct { + dropbox.Tagged +} + +// Valid tag values for GroupAccessType +const ( + GroupAccessTypeMember = "member" + GroupAccessTypeOwner = "owner" +) + +// GroupCreateArg : has no documentation (yet) +type GroupCreateArg struct { + // GroupName : Group name. + GroupName string `json:"group_name"` + // GroupExternalId : The creator of a team can associate an arbitrary + // external ID to the group. + GroupExternalId string `json:"group_external_id,omitempty"` + // GroupManagementType : Whether the team can be managed by selected users, + // or only by team admins. + GroupManagementType *team_common.GroupManagementType `json:"group_management_type,omitempty"` +} + +// NewGroupCreateArg returns a new GroupCreateArg instance +func NewGroupCreateArg(GroupName string) *GroupCreateArg { + s := new(GroupCreateArg) + s.GroupName = GroupName + return s +} + +// GroupCreateError : has no documentation (yet) +type GroupCreateError struct { + dropbox.Tagged +} + +// Valid tag values for GroupCreateError +const ( + GroupCreateErrorGroupNameAlreadyUsed = "group_name_already_used" + GroupCreateErrorGroupNameInvalid = "group_name_invalid" + GroupCreateErrorExternalIdAlreadyInUse = "external_id_already_in_use" + GroupCreateErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupCreateErrorOther = "other" +) + +// GroupSelectorError : Error that can be raised when `GroupSelector` is used. +type GroupSelectorError struct { + dropbox.Tagged +} + +// Valid tag values for GroupSelectorError +const ( + GroupSelectorErrorGroupNotFound = "group_not_found" + GroupSelectorErrorOther = "other" +) + +// GroupSelectorWithTeamGroupError : Error that can be raised when +// `GroupSelector` is used and team groups are disallowed from being used. +type GroupSelectorWithTeamGroupError struct { + dropbox.Tagged +} + +// Valid tag values for GroupSelectorWithTeamGroupError +const ( + GroupSelectorWithTeamGroupErrorGroupNotFound = "group_not_found" + GroupSelectorWithTeamGroupErrorOther = "other" + GroupSelectorWithTeamGroupErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" +) + +// GroupDeleteError : has no documentation (yet) +type GroupDeleteError struct { + dropbox.Tagged +} + +// Valid tag values for GroupDeleteError +const ( + GroupDeleteErrorGroupNotFound = "group_not_found" + GroupDeleteErrorOther = "other" + GroupDeleteErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupDeleteErrorGroupAlreadyDeleted = "group_already_deleted" +) + +// GroupFullInfo : Full description of a group. +type GroupFullInfo struct { + team_common.GroupSummary + // Members : List of group members. + Members []*GroupMemberInfo `json:"members,omitempty"` + // Created : The group creation time as a UTC timestamp in milliseconds + // since the Unix epoch. + Created uint64 `json:"created"` +} + +// NewGroupFullInfo returns a new GroupFullInfo instance +func NewGroupFullInfo(GroupName string, GroupId string, GroupManagementType *team_common.GroupManagementType, Created uint64) *GroupFullInfo { + s := new(GroupFullInfo) + s.GroupName = GroupName + s.GroupId = GroupId + s.GroupManagementType = GroupManagementType + s.Created = Created + return s +} + +// GroupMemberInfo : Profile of group member, and role in group. +type GroupMemberInfo struct { + // Profile : Profile of group member. + Profile *MemberProfile `json:"profile"` + // AccessType : The role that the user has in the group. + AccessType *GroupAccessType `json:"access_type"` +} + +// NewGroupMemberInfo returns a new GroupMemberInfo instance +func NewGroupMemberInfo(Profile *MemberProfile, AccessType *GroupAccessType) *GroupMemberInfo { + s := new(GroupMemberInfo) + s.Profile = Profile + s.AccessType = AccessType + return s +} + +// GroupMemberSelector : Argument for selecting a group and a single user. +type GroupMemberSelector struct { + // Group : Specify a group. + Group *GroupSelector `json:"group"` + // User : Identity of a user that is a member of `group`. + User *UserSelectorArg `json:"user"` +} + +// NewGroupMemberSelector returns a new GroupMemberSelector instance +func NewGroupMemberSelector(Group *GroupSelector, User *UserSelectorArg) *GroupMemberSelector { + s := new(GroupMemberSelector) + s.Group = Group + s.User = User + return s +} + +// GroupMemberSelectorError : Error that can be raised when +// `GroupMemberSelector` is used, and the user is required to be a member of the +// specified group. +type GroupMemberSelectorError struct { + dropbox.Tagged +} + +// Valid tag values for GroupMemberSelectorError +const ( + GroupMemberSelectorErrorGroupNotFound = "group_not_found" + GroupMemberSelectorErrorOther = "other" + GroupMemberSelectorErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupMemberSelectorErrorMemberNotInGroup = "member_not_in_group" +) + +// GroupMemberSetAccessTypeError : has no documentation (yet) +type GroupMemberSetAccessTypeError struct { + dropbox.Tagged +} + +// Valid tag values for GroupMemberSetAccessTypeError +const ( + GroupMemberSetAccessTypeErrorGroupNotFound = "group_not_found" + GroupMemberSetAccessTypeErrorOther = "other" + GroupMemberSetAccessTypeErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupMemberSetAccessTypeErrorMemberNotInGroup = "member_not_in_group" + GroupMemberSetAccessTypeErrorUserCannotBeManagerOfCompanyManagedGroup = "user_cannot_be_manager_of_company_managed_group" +) + +// IncludeMembersArg : has no documentation (yet) +type IncludeMembersArg struct { + // ReturnMembers : Whether to return the list of members in the group. Note + // that the default value will cause all the group members to be returned + // in the response. This may take a long time for large groups. + ReturnMembers bool `json:"return_members"` +} + +// NewIncludeMembersArg returns a new IncludeMembersArg instance +func NewIncludeMembersArg() *IncludeMembersArg { + s := new(IncludeMembersArg) + s.ReturnMembers = true + return s +} + +// GroupMembersAddArg : has no documentation (yet) +type GroupMembersAddArg struct { + IncludeMembersArg + // Group : Group to which users will be added. + Group *GroupSelector `json:"group"` + // Members : List of users to be added to the group. + Members []*MemberAccess `json:"members"` +} + +// NewGroupMembersAddArg returns a new GroupMembersAddArg instance +func NewGroupMembersAddArg(Group *GroupSelector, Members []*MemberAccess) *GroupMembersAddArg { + s := new(GroupMembersAddArg) + s.Group = Group + s.Members = Members + s.ReturnMembers = true + return s +} + +// GroupMembersAddError : has no documentation (yet) +type GroupMembersAddError struct { + dropbox.Tagged + // MembersNotInTeam : These members are not part of your team. Currently, + // you cannot add members to a group if they are not part of your team, + // though this may change in a subsequent version. To add new members to + // your Dropbox Business team, use the `membersAdd` endpoint. + MembersNotInTeam []string `json:"members_not_in_team,omitempty"` + // UsersNotFound : These users were not found in Dropbox. + UsersNotFound []string `json:"users_not_found,omitempty"` + // UserCannotBeManagerOfCompanyManagedGroup : A company-managed group cannot + // be managed by a user. + UserCannotBeManagerOfCompanyManagedGroup []string `json:"user_cannot_be_manager_of_company_managed_group,omitempty"` +} + +// Valid tag values for GroupMembersAddError +const ( + GroupMembersAddErrorGroupNotFound = "group_not_found" + GroupMembersAddErrorOther = "other" + GroupMembersAddErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupMembersAddErrorDuplicateUser = "duplicate_user" + GroupMembersAddErrorGroupNotInTeam = "group_not_in_team" + GroupMembersAddErrorMembersNotInTeam = "members_not_in_team" + GroupMembersAddErrorUsersNotFound = "users_not_found" + GroupMembersAddErrorUserMustBeActiveToBeOwner = "user_must_be_active_to_be_owner" + GroupMembersAddErrorUserCannotBeManagerOfCompanyManagedGroup = "user_cannot_be_manager_of_company_managed_group" +) + +// UnmarshalJSON deserializes into a GroupMembersAddError instance +func (u *GroupMembersAddError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // MembersNotInTeam : These members are not part of your team. + // Currently, you cannot add members to a group if they are not part of + // your team, though this may change in a subsequent version. To add new + // members to your Dropbox Business team, use the `membersAdd` endpoint. + MembersNotInTeam json.RawMessage `json:"members_not_in_team,omitempty"` + // UsersNotFound : These users were not found in Dropbox. + UsersNotFound json.RawMessage `json:"users_not_found,omitempty"` + // UserCannotBeManagerOfCompanyManagedGroup : A company-managed group + // cannot be managed by a user. + UserCannotBeManagerOfCompanyManagedGroup json.RawMessage `json:"user_cannot_be_manager_of_company_managed_group,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "members_not_in_team": + err = json.Unmarshal(body, &u.MembersNotInTeam) + + if err != nil { + return err + } + case "users_not_found": + err = json.Unmarshal(body, &u.UsersNotFound) + + if err != nil { + return err + } + case "user_cannot_be_manager_of_company_managed_group": + err = json.Unmarshal(body, &u.UserCannotBeManagerOfCompanyManagedGroup) + + if err != nil { + return err + } + } + return nil +} + +// GroupMembersChangeResult : Result returned by `groupsMembersAdd` and +// `groupsMembersRemove`. +type GroupMembersChangeResult struct { + // GroupInfo : The group info after member change operation has been + // performed. + GroupInfo *GroupFullInfo `json:"group_info"` + // AsyncJobId : An ID that can be used to obtain the status of + // granting/revoking group-owned resources. + AsyncJobId string `json:"async_job_id"` +} + +// NewGroupMembersChangeResult returns a new GroupMembersChangeResult instance +func NewGroupMembersChangeResult(GroupInfo *GroupFullInfo, AsyncJobId string) *GroupMembersChangeResult { + s := new(GroupMembersChangeResult) + s.GroupInfo = GroupInfo + s.AsyncJobId = AsyncJobId + return s +} + +// GroupMembersRemoveArg : has no documentation (yet) +type GroupMembersRemoveArg struct { + IncludeMembersArg + // Group : Group from which users will be removed. + Group *GroupSelector `json:"group"` + // Users : List of users to be removed from the group. + Users []*UserSelectorArg `json:"users"` +} + +// NewGroupMembersRemoveArg returns a new GroupMembersRemoveArg instance +func NewGroupMembersRemoveArg(Group *GroupSelector, Users []*UserSelectorArg) *GroupMembersRemoveArg { + s := new(GroupMembersRemoveArg) + s.Group = Group + s.Users = Users + s.ReturnMembers = true + return s +} + +// GroupMembersSelectorError : Error that can be raised when +// `GroupMembersSelector` is used, and the users are required to be members of +// the specified group. +type GroupMembersSelectorError struct { + dropbox.Tagged +} + +// Valid tag values for GroupMembersSelectorError +const ( + GroupMembersSelectorErrorGroupNotFound = "group_not_found" + GroupMembersSelectorErrorOther = "other" + GroupMembersSelectorErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupMembersSelectorErrorMemberNotInGroup = "member_not_in_group" +) + +// GroupMembersRemoveError : has no documentation (yet) +type GroupMembersRemoveError struct { + dropbox.Tagged + // MembersNotInTeam : These members are not part of your team. + MembersNotInTeam []string `json:"members_not_in_team,omitempty"` + // UsersNotFound : These users were not found in Dropbox. + UsersNotFound []string `json:"users_not_found,omitempty"` +} + +// Valid tag values for GroupMembersRemoveError +const ( + GroupMembersRemoveErrorGroupNotFound = "group_not_found" + GroupMembersRemoveErrorOther = "other" + GroupMembersRemoveErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupMembersRemoveErrorMemberNotInGroup = "member_not_in_group" + GroupMembersRemoveErrorGroupNotInTeam = "group_not_in_team" + GroupMembersRemoveErrorMembersNotInTeam = "members_not_in_team" + GroupMembersRemoveErrorUsersNotFound = "users_not_found" +) + +// UnmarshalJSON deserializes into a GroupMembersRemoveError instance +func (u *GroupMembersRemoveError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // MembersNotInTeam : These members are not part of your team. + MembersNotInTeam json.RawMessage `json:"members_not_in_team,omitempty"` + // UsersNotFound : These users were not found in Dropbox. + UsersNotFound json.RawMessage `json:"users_not_found,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "members_not_in_team": + err = json.Unmarshal(body, &u.MembersNotInTeam) + + if err != nil { + return err + } + case "users_not_found": + err = json.Unmarshal(body, &u.UsersNotFound) + + if err != nil { + return err + } + } + return nil +} + +// GroupMembersSelector : Argument for selecting a group and a list of users. +type GroupMembersSelector struct { + // Group : Specify a group. + Group *GroupSelector `json:"group"` + // Users : A list of users that are members of `group`. + Users *UsersSelectorArg `json:"users"` +} + +// NewGroupMembersSelector returns a new GroupMembersSelector instance +func NewGroupMembersSelector(Group *GroupSelector, Users *UsersSelectorArg) *GroupMembersSelector { + s := new(GroupMembersSelector) + s.Group = Group + s.Users = Users + return s +} + +// GroupMembersSetAccessTypeArg : has no documentation (yet) +type GroupMembersSetAccessTypeArg struct { + GroupMemberSelector + // AccessType : New group access type the user will have. + AccessType *GroupAccessType `json:"access_type"` + // ReturnMembers : Whether to return the list of members in the group. Note + // that the default value will cause all the group members to be returned + // in the response. This may take a long time for large groups. + ReturnMembers bool `json:"return_members"` +} + +// NewGroupMembersSetAccessTypeArg returns a new GroupMembersSetAccessTypeArg instance +func NewGroupMembersSetAccessTypeArg(Group *GroupSelector, User *UserSelectorArg, AccessType *GroupAccessType) *GroupMembersSetAccessTypeArg { + s := new(GroupMembersSetAccessTypeArg) + s.Group = Group + s.User = User + s.AccessType = AccessType + s.ReturnMembers = true + return s +} + +// GroupSelector : Argument for selecting a single group, either by group_id or +// by external group ID. +type GroupSelector struct { + dropbox.Tagged + // GroupId : Group ID. + GroupId string `json:"group_id,omitempty"` + // GroupExternalId : External ID of the group. + GroupExternalId string `json:"group_external_id,omitempty"` +} + +// Valid tag values for GroupSelector +const ( + GroupSelectorGroupId = "group_id" + GroupSelectorGroupExternalId = "group_external_id" +) + +// UnmarshalJSON deserializes into a GroupSelector instance +func (u *GroupSelector) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "group_id": + err = json.Unmarshal(body, &u.GroupId) + + if err != nil { + return err + } + case "group_external_id": + err = json.Unmarshal(body, &u.GroupExternalId) + + if err != nil { + return err + } + } + return nil +} + +// GroupUpdateArgs : has no documentation (yet) +type GroupUpdateArgs struct { + IncludeMembersArg + // Group : Specify a group. + Group *GroupSelector `json:"group"` + // NewGroupName : Optional argument. Set group name to this if provided. + NewGroupName string `json:"new_group_name,omitempty"` + // NewGroupExternalId : Optional argument. New group external ID. If the + // argument is None, the group's external_id won't be updated. If the + // argument is empty string, the group's external id will be cleared. + NewGroupExternalId string `json:"new_group_external_id,omitempty"` + // NewGroupManagementType : Set new group management type, if provided. + NewGroupManagementType *team_common.GroupManagementType `json:"new_group_management_type,omitempty"` +} + +// NewGroupUpdateArgs returns a new GroupUpdateArgs instance +func NewGroupUpdateArgs(Group *GroupSelector) *GroupUpdateArgs { + s := new(GroupUpdateArgs) + s.Group = Group + s.ReturnMembers = true + return s +} + +// GroupUpdateError : has no documentation (yet) +type GroupUpdateError struct { + dropbox.Tagged +} + +// Valid tag values for GroupUpdateError +const ( + GroupUpdateErrorGroupNotFound = "group_not_found" + GroupUpdateErrorOther = "other" + GroupUpdateErrorSystemManagedGroupDisallowed = "system_managed_group_disallowed" + GroupUpdateErrorGroupNameAlreadyUsed = "group_name_already_used" + GroupUpdateErrorGroupNameInvalid = "group_name_invalid" + GroupUpdateErrorExternalIdAlreadyInUse = "external_id_already_in_use" +) + +// GroupsGetInfoError : has no documentation (yet) +type GroupsGetInfoError struct { + dropbox.Tagged +} + +// Valid tag values for GroupsGetInfoError +const ( + GroupsGetInfoErrorGroupNotOnTeam = "group_not_on_team" + GroupsGetInfoErrorOther = "other" +) + +// GroupsGetInfoItem : has no documentation (yet) +type GroupsGetInfoItem struct { + dropbox.Tagged + // IdNotFound : An ID that was provided as a parameter to `groupsGetInfo`, + // and did not match a corresponding group. The ID can be a group ID, or an + // external ID, depending on how the method was called. + IdNotFound string `json:"id_not_found,omitempty"` + // GroupInfo : Info about a group. + GroupInfo *GroupFullInfo `json:"group_info,omitempty"` +} + +// Valid tag values for GroupsGetInfoItem +const ( + GroupsGetInfoItemIdNotFound = "id_not_found" + GroupsGetInfoItemGroupInfo = "group_info" +) + +// UnmarshalJSON deserializes into a GroupsGetInfoItem instance +func (u *GroupsGetInfoItem) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // GroupInfo : Info about a group. + GroupInfo json.RawMessage `json:"group_info,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "id_not_found": + err = json.Unmarshal(body, &u.IdNotFound) + + if err != nil { + return err + } + case "group_info": + err = json.Unmarshal(body, &u.GroupInfo) + + if err != nil { + return err + } + } + return nil +} + +// GroupsListArg : has no documentation (yet) +type GroupsListArg struct { + // Limit : Number of results to return per call. + Limit uint32 `json:"limit"` +} + +// NewGroupsListArg returns a new GroupsListArg instance +func NewGroupsListArg() *GroupsListArg { + s := new(GroupsListArg) + s.Limit = 1000 + return s +} + +// GroupsListContinueArg : has no documentation (yet) +type GroupsListContinueArg struct { + // Cursor : Indicates from what point to get the next set of groups. + Cursor string `json:"cursor"` +} + +// NewGroupsListContinueArg returns a new GroupsListContinueArg instance +func NewGroupsListContinueArg(Cursor string) *GroupsListContinueArg { + s := new(GroupsListContinueArg) + s.Cursor = Cursor + return s +} + +// GroupsListContinueError : has no documentation (yet) +type GroupsListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for GroupsListContinueError +const ( + GroupsListContinueErrorInvalidCursor = "invalid_cursor" + GroupsListContinueErrorOther = "other" +) + +// GroupsListResult : has no documentation (yet) +type GroupsListResult struct { + // Groups : has no documentation (yet) + Groups []*team_common.GroupSummary `json:"groups"` + // Cursor : Pass the cursor into `groupsListContinue` to obtain the + // additional groups. + Cursor string `json:"cursor"` + // HasMore : Is true if there are additional groups that have not been + // returned yet. An additional call to `groupsListContinue` can retrieve + // them. + HasMore bool `json:"has_more"` +} + +// NewGroupsListResult returns a new GroupsListResult instance +func NewGroupsListResult(Groups []*team_common.GroupSummary, Cursor string, HasMore bool) *GroupsListResult { + s := new(GroupsListResult) + s.Groups = Groups + s.Cursor = Cursor + s.HasMore = HasMore + return s +} + +// GroupsMembersListArg : has no documentation (yet) +type GroupsMembersListArg struct { + // Group : The group whose members are to be listed. + Group *GroupSelector `json:"group"` + // Limit : Number of results to return per call. + Limit uint32 `json:"limit"` +} + +// NewGroupsMembersListArg returns a new GroupsMembersListArg instance +func NewGroupsMembersListArg(Group *GroupSelector) *GroupsMembersListArg { + s := new(GroupsMembersListArg) + s.Group = Group + s.Limit = 1000 + return s +} + +// GroupsMembersListContinueArg : has no documentation (yet) +type GroupsMembersListContinueArg struct { + // Cursor : Indicates from what point to get the next set of groups. + Cursor string `json:"cursor"` +} + +// NewGroupsMembersListContinueArg returns a new GroupsMembersListContinueArg instance +func NewGroupsMembersListContinueArg(Cursor string) *GroupsMembersListContinueArg { + s := new(GroupsMembersListContinueArg) + s.Cursor = Cursor + return s +} + +// GroupsMembersListContinueError : has no documentation (yet) +type GroupsMembersListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for GroupsMembersListContinueError +const ( + GroupsMembersListContinueErrorInvalidCursor = "invalid_cursor" + GroupsMembersListContinueErrorOther = "other" +) + +// GroupsMembersListResult : has no documentation (yet) +type GroupsMembersListResult struct { + // Members : has no documentation (yet) + Members []*GroupMemberInfo `json:"members"` + // Cursor : Pass the cursor into `groupsMembersListContinue` to obtain + // additional group members. + Cursor string `json:"cursor"` + // HasMore : Is true if there are additional group members that have not + // been returned yet. An additional call to `groupsMembersListContinue` can + // retrieve them. + HasMore bool `json:"has_more"` +} + +// NewGroupsMembersListResult returns a new GroupsMembersListResult instance +func NewGroupsMembersListResult(Members []*GroupMemberInfo, Cursor string, HasMore bool) *GroupsMembersListResult { + s := new(GroupsMembersListResult) + s.Members = Members + s.Cursor = Cursor + s.HasMore = HasMore + return s +} + +// GroupsPollError : has no documentation (yet) +type GroupsPollError struct { + dropbox.Tagged +} + +// Valid tag values for GroupsPollError +const ( + GroupsPollErrorInvalidAsyncJobId = "invalid_async_job_id" + GroupsPollErrorInternalError = "internal_error" + GroupsPollErrorOther = "other" + GroupsPollErrorAccessDenied = "access_denied" +) + +// GroupsSelector : Argument for selecting a list of groups, either by +// group_ids, or external group IDs. +type GroupsSelector struct { + dropbox.Tagged + // GroupIds : List of group IDs. + GroupIds []string `json:"group_ids,omitempty"` + // GroupExternalIds : List of external IDs of groups. + GroupExternalIds []string `json:"group_external_ids,omitempty"` +} + +// Valid tag values for GroupsSelector +const ( + GroupsSelectorGroupIds = "group_ids" + GroupsSelectorGroupExternalIds = "group_external_ids" +) + +// UnmarshalJSON deserializes into a GroupsSelector instance +func (u *GroupsSelector) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // GroupIds : List of group IDs. + GroupIds json.RawMessage `json:"group_ids,omitempty"` + // GroupExternalIds : List of external IDs of groups. + GroupExternalIds json.RawMessage `json:"group_external_ids,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "group_ids": + err = json.Unmarshal(body, &u.GroupIds) + + if err != nil { + return err + } + case "group_external_ids": + err = json.Unmarshal(body, &u.GroupExternalIds) + + if err != nil { + return err + } + } + return nil +} + +// HasTeamFileEventsValue : The value for `Feature.has_team_file_events`. +type HasTeamFileEventsValue struct { + dropbox.Tagged + // Enabled : Does this team have file events. + Enabled bool `json:"enabled,omitempty"` +} + +// Valid tag values for HasTeamFileEventsValue +const ( + HasTeamFileEventsValueEnabled = "enabled" + HasTeamFileEventsValueOther = "other" +) + +// UnmarshalJSON deserializes into a HasTeamFileEventsValue instance +func (u *HasTeamFileEventsValue) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "enabled": + err = json.Unmarshal(body, &u.Enabled) + + if err != nil { + return err + } + } + return nil +} + +// HasTeamSelectiveSyncValue : The value for `Feature.has_team_selective_sync`. +type HasTeamSelectiveSyncValue struct { + dropbox.Tagged + // HasTeamSelectiveSync : Does this team have team selective sync enabled. + HasTeamSelectiveSync bool `json:"has_team_selective_sync,omitempty"` +} + +// Valid tag values for HasTeamSelectiveSyncValue +const ( + HasTeamSelectiveSyncValueHasTeamSelectiveSync = "has_team_selective_sync" + HasTeamSelectiveSyncValueOther = "other" +) + +// UnmarshalJSON deserializes into a HasTeamSelectiveSyncValue instance +func (u *HasTeamSelectiveSyncValue) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "has_team_selective_sync": + err = json.Unmarshal(body, &u.HasTeamSelectiveSync) + + if err != nil { + return err + } + } + return nil +} + +// HasTeamSharedDropboxValue : The value for `Feature.has_team_shared_dropbox`. +type HasTeamSharedDropboxValue struct { + dropbox.Tagged + // HasTeamSharedDropbox : Does this team have a shared team root. + HasTeamSharedDropbox bool `json:"has_team_shared_dropbox,omitempty"` +} + +// Valid tag values for HasTeamSharedDropboxValue +const ( + HasTeamSharedDropboxValueHasTeamSharedDropbox = "has_team_shared_dropbox" + HasTeamSharedDropboxValueOther = "other" +) + +// UnmarshalJSON deserializes into a HasTeamSharedDropboxValue instance +func (u *HasTeamSharedDropboxValue) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "has_team_shared_dropbox": + err = json.Unmarshal(body, &u.HasTeamSharedDropbox) + + if err != nil { + return err + } + } + return nil +} + +// ListMemberAppsArg : has no documentation (yet) +type ListMemberAppsArg struct { + // TeamMemberId : The team member id. + TeamMemberId string `json:"team_member_id"` +} + +// NewListMemberAppsArg returns a new ListMemberAppsArg instance +func NewListMemberAppsArg(TeamMemberId string) *ListMemberAppsArg { + s := new(ListMemberAppsArg) + s.TeamMemberId = TeamMemberId + return s +} + +// ListMemberAppsError : Error returned by `linkedAppsListMemberLinkedApps`. +type ListMemberAppsError struct { + dropbox.Tagged +} + +// Valid tag values for ListMemberAppsError +const ( + ListMemberAppsErrorMemberNotFound = "member_not_found" + ListMemberAppsErrorOther = "other" +) + +// ListMemberAppsResult : has no documentation (yet) +type ListMemberAppsResult struct { + // LinkedApiApps : List of third party applications linked by this team + // member. + LinkedApiApps []*ApiApp `json:"linked_api_apps"` +} + +// NewListMemberAppsResult returns a new ListMemberAppsResult instance +func NewListMemberAppsResult(LinkedApiApps []*ApiApp) *ListMemberAppsResult { + s := new(ListMemberAppsResult) + s.LinkedApiApps = LinkedApiApps + return s +} + +// ListMemberDevicesArg : has no documentation (yet) +type ListMemberDevicesArg struct { + // TeamMemberId : The team's member id. + TeamMemberId string `json:"team_member_id"` + // IncludeWebSessions : Whether to list web sessions of the team's member. + IncludeWebSessions bool `json:"include_web_sessions"` + // IncludeDesktopClients : Whether to list linked desktop devices of the + // team's member. + IncludeDesktopClients bool `json:"include_desktop_clients"` + // IncludeMobileClients : Whether to list linked mobile devices of the + // team's member. + IncludeMobileClients bool `json:"include_mobile_clients"` +} + +// NewListMemberDevicesArg returns a new ListMemberDevicesArg instance +func NewListMemberDevicesArg(TeamMemberId string) *ListMemberDevicesArg { + s := new(ListMemberDevicesArg) + s.TeamMemberId = TeamMemberId + s.IncludeWebSessions = true + s.IncludeDesktopClients = true + s.IncludeMobileClients = true + return s +} + +// ListMemberDevicesError : has no documentation (yet) +type ListMemberDevicesError struct { + dropbox.Tagged +} + +// Valid tag values for ListMemberDevicesError +const ( + ListMemberDevicesErrorMemberNotFound = "member_not_found" + ListMemberDevicesErrorOther = "other" +) + +// ListMemberDevicesResult : has no documentation (yet) +type ListMemberDevicesResult struct { + // ActiveWebSessions : List of web sessions made by this team member. + ActiveWebSessions []*ActiveWebSession `json:"active_web_sessions,omitempty"` + // DesktopClientSessions : List of desktop clients used by this team member. + DesktopClientSessions []*DesktopClientSession `json:"desktop_client_sessions,omitempty"` + // MobileClientSessions : List of mobile client used by this team member. + MobileClientSessions []*MobileClientSession `json:"mobile_client_sessions,omitempty"` +} + +// NewListMemberDevicesResult returns a new ListMemberDevicesResult instance +func NewListMemberDevicesResult() *ListMemberDevicesResult { + s := new(ListMemberDevicesResult) + return s +} + +// ListMembersAppsArg : Arguments for `linkedAppsListMembersLinkedApps`. +type ListMembersAppsArg struct { + // Cursor : At the first call to the `linkedAppsListMembersLinkedApps` the + // cursor shouldn't be passed. Then, if the result of the call includes a + // cursor, the following requests should include the received cursors in + // order to receive the next sub list of the team applications. + Cursor string `json:"cursor,omitempty"` +} + +// NewListMembersAppsArg returns a new ListMembersAppsArg instance +func NewListMembersAppsArg() *ListMembersAppsArg { + s := new(ListMembersAppsArg) + return s +} + +// ListMembersAppsError : Error returned by `linkedAppsListMembersLinkedApps`. +type ListMembersAppsError struct { + dropbox.Tagged +} + +// Valid tag values for ListMembersAppsError +const ( + ListMembersAppsErrorReset = "reset" + ListMembersAppsErrorOther = "other" +) + +// ListMembersAppsResult : Information returned by +// `linkedAppsListMembersLinkedApps`. +type ListMembersAppsResult struct { + // Apps : The linked applications of each member of the team. + Apps []*MemberLinkedApps `json:"apps"` + // HasMore : If true, then there are more apps available. Pass the cursor to + // `linkedAppsListMembersLinkedApps` to retrieve the rest. + HasMore bool `json:"has_more"` + // Cursor : Pass the cursor into `linkedAppsListMembersLinkedApps` to + // receive the next sub list of team's applications. + Cursor string `json:"cursor,omitempty"` +} + +// NewListMembersAppsResult returns a new ListMembersAppsResult instance +func NewListMembersAppsResult(Apps []*MemberLinkedApps, HasMore bool) *ListMembersAppsResult { + s := new(ListMembersAppsResult) + s.Apps = Apps + s.HasMore = HasMore + return s +} + +// ListMembersDevicesArg : has no documentation (yet) +type ListMembersDevicesArg struct { + // Cursor : At the first call to the `devicesListMembersDevices` the cursor + // shouldn't be passed. Then, if the result of the call includes a cursor, + // the following requests should include the received cursors in order to + // receive the next sub list of team devices. + Cursor string `json:"cursor,omitempty"` + // IncludeWebSessions : Whether to list web sessions of the team members. + IncludeWebSessions bool `json:"include_web_sessions"` + // IncludeDesktopClients : Whether to list desktop clients of the team + // members. + IncludeDesktopClients bool `json:"include_desktop_clients"` + // IncludeMobileClients : Whether to list mobile clients of the team + // members. + IncludeMobileClients bool `json:"include_mobile_clients"` +} + +// NewListMembersDevicesArg returns a new ListMembersDevicesArg instance +func NewListMembersDevicesArg() *ListMembersDevicesArg { + s := new(ListMembersDevicesArg) + s.IncludeWebSessions = true + s.IncludeDesktopClients = true + s.IncludeMobileClients = true + return s +} + +// ListMembersDevicesError : has no documentation (yet) +type ListMembersDevicesError struct { + dropbox.Tagged +} + +// Valid tag values for ListMembersDevicesError +const ( + ListMembersDevicesErrorReset = "reset" + ListMembersDevicesErrorOther = "other" +) + +// ListMembersDevicesResult : has no documentation (yet) +type ListMembersDevicesResult struct { + // Devices : The devices of each member of the team. + Devices []*MemberDevices `json:"devices"` + // HasMore : If true, then there are more devices available. Pass the cursor + // to `devicesListMembersDevices` to retrieve the rest. + HasMore bool `json:"has_more"` + // Cursor : Pass the cursor into `devicesListMembersDevices` to receive the + // next sub list of team's devices. + Cursor string `json:"cursor,omitempty"` +} + +// NewListMembersDevicesResult returns a new ListMembersDevicesResult instance +func NewListMembersDevicesResult(Devices []*MemberDevices, HasMore bool) *ListMembersDevicesResult { + s := new(ListMembersDevicesResult) + s.Devices = Devices + s.HasMore = HasMore + return s +} + +// ListTeamAppsArg : Arguments for `linkedAppsListTeamLinkedApps`. +type ListTeamAppsArg struct { + // Cursor : At the first call to the `linkedAppsListTeamLinkedApps` the + // cursor shouldn't be passed. Then, if the result of the call includes a + // cursor, the following requests should include the received cursors in + // order to receive the next sub list of the team applications. + Cursor string `json:"cursor,omitempty"` +} + +// NewListTeamAppsArg returns a new ListTeamAppsArg instance +func NewListTeamAppsArg() *ListTeamAppsArg { + s := new(ListTeamAppsArg) + return s +} + +// ListTeamAppsError : Error returned by `linkedAppsListTeamLinkedApps`. +type ListTeamAppsError struct { + dropbox.Tagged +} + +// Valid tag values for ListTeamAppsError +const ( + ListTeamAppsErrorReset = "reset" + ListTeamAppsErrorOther = "other" +) + +// ListTeamAppsResult : Information returned by `linkedAppsListTeamLinkedApps`. +type ListTeamAppsResult struct { + // Apps : The linked applications of each member of the team. + Apps []*MemberLinkedApps `json:"apps"` + // HasMore : If true, then there are more apps available. Pass the cursor to + // `linkedAppsListTeamLinkedApps` to retrieve the rest. + HasMore bool `json:"has_more"` + // Cursor : Pass the cursor into `linkedAppsListTeamLinkedApps` to receive + // the next sub list of team's applications. + Cursor string `json:"cursor,omitempty"` +} + +// NewListTeamAppsResult returns a new ListTeamAppsResult instance +func NewListTeamAppsResult(Apps []*MemberLinkedApps, HasMore bool) *ListTeamAppsResult { + s := new(ListTeamAppsResult) + s.Apps = Apps + s.HasMore = HasMore + return s +} + +// ListTeamDevicesArg : has no documentation (yet) +type ListTeamDevicesArg struct { + // Cursor : At the first call to the `devicesListTeamDevices` the cursor + // shouldn't be passed. Then, if the result of the call includes a cursor, + // the following requests should include the received cursors in order to + // receive the next sub list of team devices. + Cursor string `json:"cursor,omitempty"` + // IncludeWebSessions : Whether to list web sessions of the team members. + IncludeWebSessions bool `json:"include_web_sessions"` + // IncludeDesktopClients : Whether to list desktop clients of the team + // members. + IncludeDesktopClients bool `json:"include_desktop_clients"` + // IncludeMobileClients : Whether to list mobile clients of the team + // members. + IncludeMobileClients bool `json:"include_mobile_clients"` +} + +// NewListTeamDevicesArg returns a new ListTeamDevicesArg instance +func NewListTeamDevicesArg() *ListTeamDevicesArg { + s := new(ListTeamDevicesArg) + s.IncludeWebSessions = true + s.IncludeDesktopClients = true + s.IncludeMobileClients = true + return s +} + +// ListTeamDevicesError : has no documentation (yet) +type ListTeamDevicesError struct { + dropbox.Tagged +} + +// Valid tag values for ListTeamDevicesError +const ( + ListTeamDevicesErrorReset = "reset" + ListTeamDevicesErrorOther = "other" +) + +// ListTeamDevicesResult : has no documentation (yet) +type ListTeamDevicesResult struct { + // Devices : The devices of each member of the team. + Devices []*MemberDevices `json:"devices"` + // HasMore : If true, then there are more devices available. Pass the cursor + // to `devicesListTeamDevices` to retrieve the rest. + HasMore bool `json:"has_more"` + // Cursor : Pass the cursor into `devicesListTeamDevices` to receive the + // next sub list of team's devices. + Cursor string `json:"cursor,omitempty"` +} + +// NewListTeamDevicesResult returns a new ListTeamDevicesResult instance +func NewListTeamDevicesResult(Devices []*MemberDevices, HasMore bool) *ListTeamDevicesResult { + s := new(ListTeamDevicesResult) + s.Devices = Devices + s.HasMore = HasMore + return s +} + +// MemberAccess : Specify access type a member should have when joined to a +// group. +type MemberAccess struct { + // User : Identity of a user. + User *UserSelectorArg `json:"user"` + // AccessType : Access type. + AccessType *GroupAccessType `json:"access_type"` +} + +// NewMemberAccess returns a new MemberAccess instance +func NewMemberAccess(User *UserSelectorArg, AccessType *GroupAccessType) *MemberAccess { + s := new(MemberAccess) + s.User = User + s.AccessType = AccessType + return s +} + +// MemberAddArg : has no documentation (yet) +type MemberAddArg struct { + // MemberEmail : has no documentation (yet) + MemberEmail string `json:"member_email"` + // MemberGivenName : Member's first name. + MemberGivenName string `json:"member_given_name,omitempty"` + // MemberSurname : Member's last name. + MemberSurname string `json:"member_surname,omitempty"` + // MemberExternalId : External ID for member. + MemberExternalId string `json:"member_external_id,omitempty"` + // MemberPersistentId : Persistent ID for member. This field is only + // available to teams using persistent ID SAML configuration. + MemberPersistentId string `json:"member_persistent_id,omitempty"` + // SendWelcomeEmail : Whether to send a welcome email to the member. If + // send_welcome_email is false, no email invitation will be sent to the + // user. This may be useful for apps using single sign-on (SSO) flows for + // onboarding that want to handle announcements themselves. + SendWelcomeEmail bool `json:"send_welcome_email"` + // Role : has no documentation (yet) + Role *AdminTier `json:"role"` + // IsDirectoryRestricted : Whether a user is directory restricted. + IsDirectoryRestricted bool `json:"is_directory_restricted,omitempty"` +} + +// NewMemberAddArg returns a new MemberAddArg instance +func NewMemberAddArg(MemberEmail string) *MemberAddArg { + s := new(MemberAddArg) + s.MemberEmail = MemberEmail + s.SendWelcomeEmail = true + s.Role = &AdminTier{Tagged: dropbox.Tagged{"member_only"}} + return s +} + +// MemberAddResult : Describes the result of attempting to add a single user to +// the team. 'success' is the only value indicating that a user was indeed added +// to the team - the other values explain the type of failure that occurred, and +// include the email of the user for which the operation has failed. +type MemberAddResult struct { + dropbox.Tagged + // Success : Describes a user that was successfully added to the team. + Success *TeamMemberInfo `json:"success,omitempty"` + // TeamLicenseLimit : Team is already full. The organization has no + // available licenses. + TeamLicenseLimit string `json:"team_license_limit,omitempty"` + // FreeTeamMemberLimitReached : Team is already full. The free team member + // limit has been reached. + FreeTeamMemberLimitReached string `json:"free_team_member_limit_reached,omitempty"` + // UserAlreadyOnTeam : User is already on this team. The provided email + // address is associated with a user who is already a member of (including + // in recoverable state) or invited to the team. + UserAlreadyOnTeam string `json:"user_already_on_team,omitempty"` + // UserOnAnotherTeam : User is already on another team. The provided email + // address is associated with a user that is already a member or invited to + // another team. + UserOnAnotherTeam string `json:"user_on_another_team,omitempty"` + // UserAlreadyPaired : User is already paired. + UserAlreadyPaired string `json:"user_already_paired,omitempty"` + // UserMigrationFailed : User migration has failed. + UserMigrationFailed string `json:"user_migration_failed,omitempty"` + // DuplicateExternalMemberId : A user with the given external member ID + // already exists on the team (including in recoverable state). + DuplicateExternalMemberId string `json:"duplicate_external_member_id,omitempty"` + // DuplicateMemberPersistentId : A user with the given persistent ID already + // exists on the team (including in recoverable state). + DuplicateMemberPersistentId string `json:"duplicate_member_persistent_id,omitempty"` + // PersistentIdDisabled : Persistent ID is only available to teams with + // persistent ID SAML configuration. Please contact Dropbox for more + // information. + PersistentIdDisabled string `json:"persistent_id_disabled,omitempty"` + // UserCreationFailed : User creation has failed. + UserCreationFailed string `json:"user_creation_failed,omitempty"` +} + +// Valid tag values for MemberAddResult +const ( + MemberAddResultSuccess = "success" + MemberAddResultTeamLicenseLimit = "team_license_limit" + MemberAddResultFreeTeamMemberLimitReached = "free_team_member_limit_reached" + MemberAddResultUserAlreadyOnTeam = "user_already_on_team" + MemberAddResultUserOnAnotherTeam = "user_on_another_team" + MemberAddResultUserAlreadyPaired = "user_already_paired" + MemberAddResultUserMigrationFailed = "user_migration_failed" + MemberAddResultDuplicateExternalMemberId = "duplicate_external_member_id" + MemberAddResultDuplicateMemberPersistentId = "duplicate_member_persistent_id" + MemberAddResultPersistentIdDisabled = "persistent_id_disabled" + MemberAddResultUserCreationFailed = "user_creation_failed" +) + +// UnmarshalJSON deserializes into a MemberAddResult instance +func (u *MemberAddResult) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Success : Describes a user that was successfully added to the team. + Success json.RawMessage `json:"success,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "success": + err = json.Unmarshal(body, &u.Success) + + if err != nil { + return err + } + case "team_license_limit": + err = json.Unmarshal(body, &u.TeamLicenseLimit) + + if err != nil { + return err + } + case "free_team_member_limit_reached": + err = json.Unmarshal(body, &u.FreeTeamMemberLimitReached) + + if err != nil { + return err + } + case "user_already_on_team": + err = json.Unmarshal(body, &u.UserAlreadyOnTeam) + + if err != nil { + return err + } + case "user_on_another_team": + err = json.Unmarshal(body, &u.UserOnAnotherTeam) + + if err != nil { + return err + } + case "user_already_paired": + err = json.Unmarshal(body, &u.UserAlreadyPaired) + + if err != nil { + return err + } + case "user_migration_failed": + err = json.Unmarshal(body, &u.UserMigrationFailed) + + if err != nil { + return err + } + case "duplicate_external_member_id": + err = json.Unmarshal(body, &u.DuplicateExternalMemberId) + + if err != nil { + return err + } + case "duplicate_member_persistent_id": + err = json.Unmarshal(body, &u.DuplicateMemberPersistentId) + + if err != nil { + return err + } + case "persistent_id_disabled": + err = json.Unmarshal(body, &u.PersistentIdDisabled) + + if err != nil { + return err + } + case "user_creation_failed": + err = json.Unmarshal(body, &u.UserCreationFailed) + + if err != nil { + return err + } + } + return nil +} + +// MemberDevices : Information on devices of a team's member. +type MemberDevices struct { + // TeamMemberId : The member unique Id. + TeamMemberId string `json:"team_member_id"` + // WebSessions : List of web sessions made by this team member. + WebSessions []*ActiveWebSession `json:"web_sessions,omitempty"` + // DesktopClients : List of desktop clients by this team member. + DesktopClients []*DesktopClientSession `json:"desktop_clients,omitempty"` + // MobileClients : List of mobile clients by this team member. + MobileClients []*MobileClientSession `json:"mobile_clients,omitempty"` +} + +// NewMemberDevices returns a new MemberDevices instance +func NewMemberDevices(TeamMemberId string) *MemberDevices { + s := new(MemberDevices) + s.TeamMemberId = TeamMemberId + return s +} + +// MemberLinkedApps : Information on linked applications of a team member. +type MemberLinkedApps struct { + // TeamMemberId : The member unique Id. + TeamMemberId string `json:"team_member_id"` + // LinkedApiApps : List of third party applications linked by this team + // member. + LinkedApiApps []*ApiApp `json:"linked_api_apps"` +} + +// NewMemberLinkedApps returns a new MemberLinkedApps instance +func NewMemberLinkedApps(TeamMemberId string, LinkedApiApps []*ApiApp) *MemberLinkedApps { + s := new(MemberLinkedApps) + s.TeamMemberId = TeamMemberId + s.LinkedApiApps = LinkedApiApps + return s +} + +// MemberProfile : Basic member profile. +type MemberProfile struct { + // TeamMemberId : ID of user as a member of a team. + TeamMemberId string `json:"team_member_id"` + // ExternalId : External ID that a team can attach to the user. An + // application using the API may find it easier to use their own IDs instead + // of Dropbox IDs like account_id or team_member_id. + ExternalId string `json:"external_id,omitempty"` + // AccountId : A user's account identifier. + AccountId string `json:"account_id,omitempty"` + // Email : Email address of user. + Email string `json:"email"` + // EmailVerified : Is true if the user's email is verified to be owned by + // the user. + EmailVerified bool `json:"email_verified"` + // Status : The user's status as a member of a specific team. + Status *TeamMemberStatus `json:"status"` + // Name : Representations for a person's name. + Name *users.Name `json:"name"` + // MembershipType : The user's membership type: full (normal team member) vs + // limited (does not use a license; no access to the team's shared quota). + MembershipType *TeamMembershipType `json:"membership_type"` + // JoinedOn : The date and time the user joined as a member of a specific + // team. + JoinedOn time.Time `json:"joined_on,omitempty"` + // PersistentId : Persistent ID that a team can attach to the user. The + // persistent ID is unique ID to be used for SAML authentication. + PersistentId string `json:"persistent_id,omitempty"` + // IsDirectoryRestricted : Whether the user is a directory restricted user. + IsDirectoryRestricted bool `json:"is_directory_restricted,omitempty"` +} + +// NewMemberProfile returns a new MemberProfile instance +func NewMemberProfile(TeamMemberId string, Email string, EmailVerified bool, Status *TeamMemberStatus, Name *users.Name, MembershipType *TeamMembershipType) *MemberProfile { + s := new(MemberProfile) + s.TeamMemberId = TeamMemberId + s.Email = Email + s.EmailVerified = EmailVerified + s.Status = Status + s.Name = Name + s.MembershipType = MembershipType + return s +} + +// UserSelectorError : Error that can be returned whenever a struct derived from +// `UserSelectorArg` is used. +type UserSelectorError struct { + dropbox.Tagged +} + +// Valid tag values for UserSelectorError +const ( + UserSelectorErrorUserNotFound = "user_not_found" +) + +// MemberSelectorError : has no documentation (yet) +type MemberSelectorError struct { + dropbox.Tagged +} + +// Valid tag values for MemberSelectorError +const ( + MemberSelectorErrorUserNotFound = "user_not_found" + MemberSelectorErrorUserNotInTeam = "user_not_in_team" +) + +// MembersAddArg : has no documentation (yet) +type MembersAddArg struct { + // NewMembers : Details of new members to be added to the team. + NewMembers []*MemberAddArg `json:"new_members"` + // ForceAsync : Whether to force the add to happen asynchronously. + ForceAsync bool `json:"force_async"` +} + +// NewMembersAddArg returns a new MembersAddArg instance +func NewMembersAddArg(NewMembers []*MemberAddArg) *MembersAddArg { + s := new(MembersAddArg) + s.NewMembers = NewMembers + s.ForceAsync = false + return s +} + +// MembersAddJobStatus : has no documentation (yet) +type MembersAddJobStatus struct { + dropbox.Tagged + // Complete : The asynchronous job has finished. For each member that was + // specified in the parameter `MembersAddArg` that was provided to + // `membersAdd`, a corresponding item is returned in this list. + Complete []*MemberAddResult `json:"complete,omitempty"` + // Failed : The asynchronous job returned an error. The string contains an + // error message. + Failed string `json:"failed,omitempty"` +} + +// Valid tag values for MembersAddJobStatus +const ( + MembersAddJobStatusInProgress = "in_progress" + MembersAddJobStatusComplete = "complete" + MembersAddJobStatusFailed = "failed" +) + +// UnmarshalJSON deserializes into a MembersAddJobStatus instance +func (u *MembersAddJobStatus) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Complete : The asynchronous job has finished. For each member that + // was specified in the parameter `MembersAddArg` that was provided to + // `membersAdd`, a corresponding item is returned in this list. + Complete []json.RawMessage `json:"complete,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "complete": + err = json.Unmarshal(body, &u.Complete) + + if err != nil { + return err + } + case "failed": + err = json.Unmarshal(body, &u.Failed) + + if err != nil { + return err + } + } + return nil +} + +// MembersAddLaunch : has no documentation (yet) +type MembersAddLaunch struct { + dropbox.Tagged + // AsyncJobId : This response indicates that the processing is asynchronous. + // The string is an id that can be used to obtain the status of the + // asynchronous job. + AsyncJobId string `json:"async_job_id,omitempty"` + // Complete : has no documentation (yet) + Complete []*MemberAddResult `json:"complete,omitempty"` +} + +// Valid tag values for MembersAddLaunch +const ( + MembersAddLaunchAsyncJobId = "async_job_id" + MembersAddLaunchComplete = "complete" +) + +// UnmarshalJSON deserializes into a MembersAddLaunch instance +func (u *MembersAddLaunch) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Complete : has no documentation (yet) + Complete []json.RawMessage `json:"complete,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "async_job_id": + err = json.Unmarshal(body, &u.AsyncJobId) + + if err != nil { + return err + } + case "complete": + err = json.Unmarshal(body, &u.Complete) + + if err != nil { + return err + } + } + return nil +} + +// MembersDeactivateArg : Exactly one of team_member_id, email, or external_id +// must be provided to identify the user account. +type MembersDeactivateArg struct { + // User : Identity of user to remove/suspend. + User *UserSelectorArg `json:"user"` + // WipeData : If provided, controls if the user's data will be deleted on + // their linked devices. + WipeData bool `json:"wipe_data"` +} + +// NewMembersDeactivateArg returns a new MembersDeactivateArg instance +func NewMembersDeactivateArg(User *UserSelectorArg) *MembersDeactivateArg { + s := new(MembersDeactivateArg) + s.User = User + s.WipeData = true + return s +} + +// MembersDeactivateError : has no documentation (yet) +type MembersDeactivateError struct { + dropbox.Tagged +} + +// Valid tag values for MembersDeactivateError +const ( + MembersDeactivateErrorUserNotFound = "user_not_found" + MembersDeactivateErrorUserNotInTeam = "user_not_in_team" + MembersDeactivateErrorOther = "other" +) + +// MembersGetInfoArgs : has no documentation (yet) +type MembersGetInfoArgs struct { + // Members : List of team members. + Members []*UserSelectorArg `json:"members"` +} + +// NewMembersGetInfoArgs returns a new MembersGetInfoArgs instance +func NewMembersGetInfoArgs(Members []*UserSelectorArg) *MembersGetInfoArgs { + s := new(MembersGetInfoArgs) + s.Members = Members + return s +} + +// MembersGetInfoError : +type MembersGetInfoError struct { + dropbox.Tagged +} + +// Valid tag values for MembersGetInfoError +const ( + MembersGetInfoErrorOther = "other" +) + +// MembersGetInfoItem : Describes a result obtained for a single user whose id +// was specified in the parameter of `membersGetInfo`. +type MembersGetInfoItem struct { + dropbox.Tagged + // IdNotFound : An ID that was provided as a parameter to `membersGetInfo`, + // and did not match a corresponding user. This might be a team_member_id, + // an email, or an external ID, depending on how the method was called. + IdNotFound string `json:"id_not_found,omitempty"` + // MemberInfo : Info about a team member. + MemberInfo *TeamMemberInfo `json:"member_info,omitempty"` +} + +// Valid tag values for MembersGetInfoItem +const ( + MembersGetInfoItemIdNotFound = "id_not_found" + MembersGetInfoItemMemberInfo = "member_info" +) + +// UnmarshalJSON deserializes into a MembersGetInfoItem instance +func (u *MembersGetInfoItem) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // MemberInfo : Info about a team member. + MemberInfo json.RawMessage `json:"member_info,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "id_not_found": + err = json.Unmarshal(body, &u.IdNotFound) + + if err != nil { + return err + } + case "member_info": + err = json.Unmarshal(body, &u.MemberInfo) + + if err != nil { + return err + } + } + return nil +} + +// MembersListArg : has no documentation (yet) +type MembersListArg struct { + // Limit : Number of results to return per call. + Limit uint32 `json:"limit"` + // IncludeRemoved : Whether to return removed members. + IncludeRemoved bool `json:"include_removed"` +} + +// NewMembersListArg returns a new MembersListArg instance +func NewMembersListArg() *MembersListArg { + s := new(MembersListArg) + s.Limit = 1000 + s.IncludeRemoved = false + return s +} + +// MembersListContinueArg : has no documentation (yet) +type MembersListContinueArg struct { + // Cursor : Indicates from what point to get the next set of members. + Cursor string `json:"cursor"` +} + +// NewMembersListContinueArg returns a new MembersListContinueArg instance +func NewMembersListContinueArg(Cursor string) *MembersListContinueArg { + s := new(MembersListContinueArg) + s.Cursor = Cursor + return s +} + +// MembersListContinueError : has no documentation (yet) +type MembersListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for MembersListContinueError +const ( + MembersListContinueErrorInvalidCursor = "invalid_cursor" + MembersListContinueErrorOther = "other" +) + +// MembersListError : +type MembersListError struct { + dropbox.Tagged +} + +// Valid tag values for MembersListError +const ( + MembersListErrorOther = "other" +) + +// MembersListResult : has no documentation (yet) +type MembersListResult struct { + // Members : List of team members. + Members []*TeamMemberInfo `json:"members"` + // Cursor : Pass the cursor into `membersListContinue` to obtain the + // additional members. + Cursor string `json:"cursor"` + // HasMore : Is true if there are additional team members that have not been + // returned yet. An additional call to `membersListContinue` can retrieve + // them. + HasMore bool `json:"has_more"` +} + +// NewMembersListResult returns a new MembersListResult instance +func NewMembersListResult(Members []*TeamMemberInfo, Cursor string, HasMore bool) *MembersListResult { + s := new(MembersListResult) + s.Members = Members + s.Cursor = Cursor + s.HasMore = HasMore + return s +} + +// MembersRecoverArg : Exactly one of team_member_id, email, or external_id must +// be provided to identify the user account. +type MembersRecoverArg struct { + // User : Identity of user to recover. + User *UserSelectorArg `json:"user"` +} + +// NewMembersRecoverArg returns a new MembersRecoverArg instance +func NewMembersRecoverArg(User *UserSelectorArg) *MembersRecoverArg { + s := new(MembersRecoverArg) + s.User = User + return s +} + +// MembersRecoverError : has no documentation (yet) +type MembersRecoverError struct { + dropbox.Tagged +} + +// Valid tag values for MembersRecoverError +const ( + MembersRecoverErrorUserNotFound = "user_not_found" + MembersRecoverErrorUserUnrecoverable = "user_unrecoverable" + MembersRecoverErrorUserNotInTeam = "user_not_in_team" + MembersRecoverErrorTeamLicenseLimit = "team_license_limit" + MembersRecoverErrorOther = "other" +) + +// MembersRemoveArg : has no documentation (yet) +type MembersRemoveArg struct { + MembersDeactivateArg + // TransferDestId : If provided, files from the deleted member account will + // be transferred to this user. + TransferDestId *UserSelectorArg `json:"transfer_dest_id,omitempty"` + // TransferAdminId : If provided, errors during the transfer process will be + // sent via email to this user. If the transfer_dest_id argument was + // provided, then this argument must be provided as well. + TransferAdminId *UserSelectorArg `json:"transfer_admin_id,omitempty"` + // KeepAccount : Downgrade the member to a Basic account. The user will + // retain the email address associated with their Dropbox account and data + // in their account that is not restricted to team members. In order to keep + // the account the argument wipe_data should be set to False. + KeepAccount bool `json:"keep_account"` +} + +// NewMembersRemoveArg returns a new MembersRemoveArg instance +func NewMembersRemoveArg(User *UserSelectorArg) *MembersRemoveArg { + s := new(MembersRemoveArg) + s.User = User + s.WipeData = true + s.KeepAccount = false + return s +} + +// MembersRemoveError : has no documentation (yet) +type MembersRemoveError struct { + dropbox.Tagged +} + +// Valid tag values for MembersRemoveError +const ( + MembersRemoveErrorUserNotFound = "user_not_found" + MembersRemoveErrorUserNotInTeam = "user_not_in_team" + MembersRemoveErrorOther = "other" + MembersRemoveErrorRemoveLastAdmin = "remove_last_admin" + MembersRemoveErrorRemovedAndTransferDestShouldDiffer = "removed_and_transfer_dest_should_differ" + MembersRemoveErrorRemovedAndTransferAdminShouldDiffer = "removed_and_transfer_admin_should_differ" + MembersRemoveErrorTransferDestUserNotFound = "transfer_dest_user_not_found" + MembersRemoveErrorTransferDestUserNotInTeam = "transfer_dest_user_not_in_team" + MembersRemoveErrorTransferAdminUserNotFound = "transfer_admin_user_not_found" + MembersRemoveErrorTransferAdminUserNotInTeam = "transfer_admin_user_not_in_team" + MembersRemoveErrorUnspecifiedTransferAdminId = "unspecified_transfer_admin_id" + MembersRemoveErrorTransferAdminIsNotAdmin = "transfer_admin_is_not_admin" + MembersRemoveErrorCannotKeepAccountAndTransfer = "cannot_keep_account_and_transfer" + MembersRemoveErrorCannotKeepAccountAndDeleteData = "cannot_keep_account_and_delete_data" + MembersRemoveErrorEmailAddressTooLongToBeDisabled = "email_address_too_long_to_be_disabled" + MembersRemoveErrorCannotKeepInvitedUserAccount = "cannot_keep_invited_user_account" +) + +// MembersSendWelcomeError : +type MembersSendWelcomeError struct { + dropbox.Tagged +} + +// Valid tag values for MembersSendWelcomeError +const ( + MembersSendWelcomeErrorUserNotFound = "user_not_found" + MembersSendWelcomeErrorUserNotInTeam = "user_not_in_team" + MembersSendWelcomeErrorOther = "other" +) + +// MembersSetPermissionsArg : Exactly one of team_member_id, email, or +// external_id must be provided to identify the user account. +type MembersSetPermissionsArg struct { + // User : Identity of user whose role will be set. + User *UserSelectorArg `json:"user"` + // NewRole : The new role of the member. + NewRole *AdminTier `json:"new_role"` +} + +// NewMembersSetPermissionsArg returns a new MembersSetPermissionsArg instance +func NewMembersSetPermissionsArg(User *UserSelectorArg, NewRole *AdminTier) *MembersSetPermissionsArg { + s := new(MembersSetPermissionsArg) + s.User = User + s.NewRole = NewRole + return s +} + +// MembersSetPermissionsError : has no documentation (yet) +type MembersSetPermissionsError struct { + dropbox.Tagged +} + +// Valid tag values for MembersSetPermissionsError +const ( + MembersSetPermissionsErrorUserNotFound = "user_not_found" + MembersSetPermissionsErrorLastAdmin = "last_admin" + MembersSetPermissionsErrorUserNotInTeam = "user_not_in_team" + MembersSetPermissionsErrorCannotSetPermissions = "cannot_set_permissions" + MembersSetPermissionsErrorTeamLicenseLimit = "team_license_limit" + MembersSetPermissionsErrorOther = "other" +) + +// MembersSetPermissionsResult : has no documentation (yet) +type MembersSetPermissionsResult struct { + // TeamMemberId : The member ID of the user to which the change was applied. + TeamMemberId string `json:"team_member_id"` + // Role : The role after the change. + Role *AdminTier `json:"role"` +} + +// NewMembersSetPermissionsResult returns a new MembersSetPermissionsResult instance +func NewMembersSetPermissionsResult(TeamMemberId string, Role *AdminTier) *MembersSetPermissionsResult { + s := new(MembersSetPermissionsResult) + s.TeamMemberId = TeamMemberId + s.Role = Role + return s +} + +// MembersSetProfileArg : Exactly one of team_member_id, email, or external_id +// must be provided to identify the user account. At least one of new_email, +// new_external_id, new_given_name, and/or new_surname must be provided. +type MembersSetProfileArg struct { + // User : Identity of user whose profile will be set. + User *UserSelectorArg `json:"user"` + // NewEmail : New email for member. + NewEmail string `json:"new_email,omitempty"` + // NewExternalId : New external ID for member. + NewExternalId string `json:"new_external_id,omitempty"` + // NewGivenName : New given name for member. + NewGivenName string `json:"new_given_name,omitempty"` + // NewSurname : New surname for member. + NewSurname string `json:"new_surname,omitempty"` + // NewPersistentId : New persistent ID. This field only available to teams + // using persistent ID SAML configuration. + NewPersistentId string `json:"new_persistent_id,omitempty"` + // NewIsDirectoryRestricted : New value for whether the user is a directory + // restricted user. + NewIsDirectoryRestricted bool `json:"new_is_directory_restricted,omitempty"` +} + +// NewMembersSetProfileArg returns a new MembersSetProfileArg instance +func NewMembersSetProfileArg(User *UserSelectorArg) *MembersSetProfileArg { + s := new(MembersSetProfileArg) + s.User = User + return s +} + +// MembersSetProfileError : has no documentation (yet) +type MembersSetProfileError struct { + dropbox.Tagged +} + +// Valid tag values for MembersSetProfileError +const ( + MembersSetProfileErrorUserNotFound = "user_not_found" + MembersSetProfileErrorUserNotInTeam = "user_not_in_team" + MembersSetProfileErrorExternalIdAndNewExternalIdUnsafe = "external_id_and_new_external_id_unsafe" + MembersSetProfileErrorNoNewDataSpecified = "no_new_data_specified" + MembersSetProfileErrorEmailReservedForOtherUser = "email_reserved_for_other_user" + MembersSetProfileErrorExternalIdUsedByOtherUser = "external_id_used_by_other_user" + MembersSetProfileErrorSetProfileDisallowed = "set_profile_disallowed" + MembersSetProfileErrorParamCannotBeEmpty = "param_cannot_be_empty" + MembersSetProfileErrorPersistentIdDisabled = "persistent_id_disabled" + MembersSetProfileErrorPersistentIdUsedByOtherUser = "persistent_id_used_by_other_user" + MembersSetProfileErrorDirectoryRestrictedOff = "directory_restricted_off" + MembersSetProfileErrorOther = "other" +) + +// MembersSuspendError : has no documentation (yet) +type MembersSuspendError struct { + dropbox.Tagged +} + +// Valid tag values for MembersSuspendError +const ( + MembersSuspendErrorUserNotFound = "user_not_found" + MembersSuspendErrorUserNotInTeam = "user_not_in_team" + MembersSuspendErrorOther = "other" + MembersSuspendErrorSuspendInactiveUser = "suspend_inactive_user" + MembersSuspendErrorSuspendLastAdmin = "suspend_last_admin" + MembersSuspendErrorTeamLicenseLimit = "team_license_limit" +) + +// MembersUnsuspendArg : Exactly one of team_member_id, email, or external_id +// must be provided to identify the user account. +type MembersUnsuspendArg struct { + // User : Identity of user to unsuspend. + User *UserSelectorArg `json:"user"` +} + +// NewMembersUnsuspendArg returns a new MembersUnsuspendArg instance +func NewMembersUnsuspendArg(User *UserSelectorArg) *MembersUnsuspendArg { + s := new(MembersUnsuspendArg) + s.User = User + return s +} + +// MembersUnsuspendError : has no documentation (yet) +type MembersUnsuspendError struct { + dropbox.Tagged +} + +// Valid tag values for MembersUnsuspendError +const ( + MembersUnsuspendErrorUserNotFound = "user_not_found" + MembersUnsuspendErrorUserNotInTeam = "user_not_in_team" + MembersUnsuspendErrorOther = "other" + MembersUnsuspendErrorUnsuspendNonSuspendedMember = "unsuspend_non_suspended_member" + MembersUnsuspendErrorTeamLicenseLimit = "team_license_limit" +) + +// MobileClientPlatform : has no documentation (yet) +type MobileClientPlatform struct { + dropbox.Tagged +} + +// Valid tag values for MobileClientPlatform +const ( + MobileClientPlatformIphone = "iphone" + MobileClientPlatformIpad = "ipad" + MobileClientPlatformAndroid = "android" + MobileClientPlatformWindowsPhone = "windows_phone" + MobileClientPlatformBlackberry = "blackberry" + MobileClientPlatformOther = "other" +) + +// MobileClientSession : Information about linked Dropbox mobile client +// sessions. +type MobileClientSession struct { + DeviceSession + // DeviceName : The device name. + DeviceName string `json:"device_name"` + // ClientType : The mobile application type. + ClientType *MobileClientPlatform `json:"client_type"` + // ClientVersion : The dropbox client version. + ClientVersion string `json:"client_version,omitempty"` + // OsVersion : The hosting OS version. + OsVersion string `json:"os_version,omitempty"` + // LastCarrier : last carrier used by the device. + LastCarrier string `json:"last_carrier,omitempty"` +} + +// NewMobileClientSession returns a new MobileClientSession instance +func NewMobileClientSession(SessionId string, DeviceName string, ClientType *MobileClientPlatform) *MobileClientSession { + s := new(MobileClientSession) + s.SessionId = SessionId + s.DeviceName = DeviceName + s.ClientType = ClientType + return s +} + +// NamespaceMetadata : Properties of a namespace. +type NamespaceMetadata struct { + // Name : The name of this namespace. + Name string `json:"name"` + // NamespaceId : The ID of this namespace. + NamespaceId string `json:"namespace_id"` + // NamespaceType : The type of this namespace. + NamespaceType *NamespaceType `json:"namespace_type"` + // TeamMemberId : If this is a team member or app folder, the ID of the + // owning team member. Otherwise, this field is not present. + TeamMemberId string `json:"team_member_id,omitempty"` +} + +// NewNamespaceMetadata returns a new NamespaceMetadata instance +func NewNamespaceMetadata(Name string, NamespaceId string, NamespaceType *NamespaceType) *NamespaceMetadata { + s := new(NamespaceMetadata) + s.Name = Name + s.NamespaceId = NamespaceId + s.NamespaceType = NamespaceType + return s +} + +// NamespaceType : has no documentation (yet) +type NamespaceType struct { + dropbox.Tagged +} + +// Valid tag values for NamespaceType +const ( + NamespaceTypeAppFolder = "app_folder" + NamespaceTypeSharedFolder = "shared_folder" + NamespaceTypeTeamFolder = "team_folder" + NamespaceTypeTeamMemberFolder = "team_member_folder" + NamespaceTypeOther = "other" +) + +// RemoveCustomQuotaResult : User result for setting member custom quota. +type RemoveCustomQuotaResult struct { + dropbox.Tagged + // Success : Successfully removed user. + Success *UserSelectorArg `json:"success,omitempty"` + // InvalidUser : Invalid user (not in team). + InvalidUser *UserSelectorArg `json:"invalid_user,omitempty"` +} + +// Valid tag values for RemoveCustomQuotaResult +const ( + RemoveCustomQuotaResultSuccess = "success" + RemoveCustomQuotaResultInvalidUser = "invalid_user" + RemoveCustomQuotaResultOther = "other" +) + +// UnmarshalJSON deserializes into a RemoveCustomQuotaResult instance +func (u *RemoveCustomQuotaResult) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Success : Successfully removed user. + Success json.RawMessage `json:"success,omitempty"` + // InvalidUser : Invalid user (not in team). + InvalidUser json.RawMessage `json:"invalid_user,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "success": + err = json.Unmarshal(w.Success, &u.Success) + + if err != nil { + return err + } + case "invalid_user": + err = json.Unmarshal(w.InvalidUser, &u.InvalidUser) + + if err != nil { + return err + } + } + return nil +} + +// RemovedStatus : has no documentation (yet) +type RemovedStatus struct { + // IsRecoverable : True if the removed team member is recoverable. + IsRecoverable bool `json:"is_recoverable"` +} + +// NewRemovedStatus returns a new RemovedStatus instance +func NewRemovedStatus(IsRecoverable bool) *RemovedStatus { + s := new(RemovedStatus) + s.IsRecoverable = IsRecoverable + return s +} + +// RevokeDesktopClientArg : has no documentation (yet) +type RevokeDesktopClientArg struct { + DeviceSessionArg + // DeleteOnUnlink : Whether to delete all files of the account (this is + // possible only if supported by the desktop client and will be made the + // next time the client access the account). + DeleteOnUnlink bool `json:"delete_on_unlink"` +} + +// NewRevokeDesktopClientArg returns a new RevokeDesktopClientArg instance +func NewRevokeDesktopClientArg(SessionId string, TeamMemberId string) *RevokeDesktopClientArg { + s := new(RevokeDesktopClientArg) + s.SessionId = SessionId + s.TeamMemberId = TeamMemberId + s.DeleteOnUnlink = false + return s +} + +// RevokeDeviceSessionArg : has no documentation (yet) +type RevokeDeviceSessionArg struct { + dropbox.Tagged + // WebSession : End an active session. + WebSession *DeviceSessionArg `json:"web_session,omitempty"` + // DesktopClient : Unlink a linked desktop device. + DesktopClient *RevokeDesktopClientArg `json:"desktop_client,omitempty"` + // MobileClient : Unlink a linked mobile device. + MobileClient *DeviceSessionArg `json:"mobile_client,omitempty"` +} + +// Valid tag values for RevokeDeviceSessionArg +const ( + RevokeDeviceSessionArgWebSession = "web_session" + RevokeDeviceSessionArgDesktopClient = "desktop_client" + RevokeDeviceSessionArgMobileClient = "mobile_client" +) + +// UnmarshalJSON deserializes into a RevokeDeviceSessionArg instance +func (u *RevokeDeviceSessionArg) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // WebSession : End an active session. + WebSession json.RawMessage `json:"web_session,omitempty"` + // DesktopClient : Unlink a linked desktop device. + DesktopClient json.RawMessage `json:"desktop_client,omitempty"` + // MobileClient : Unlink a linked mobile device. + MobileClient json.RawMessage `json:"mobile_client,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "web_session": + err = json.Unmarshal(body, &u.WebSession) + + if err != nil { + return err + } + case "desktop_client": + err = json.Unmarshal(body, &u.DesktopClient) + + if err != nil { + return err + } + case "mobile_client": + err = json.Unmarshal(body, &u.MobileClient) + + if err != nil { + return err + } + } + return nil +} + +// RevokeDeviceSessionBatchArg : has no documentation (yet) +type RevokeDeviceSessionBatchArg struct { + // RevokeDevices : has no documentation (yet) + RevokeDevices []*RevokeDeviceSessionArg `json:"revoke_devices"` +} + +// NewRevokeDeviceSessionBatchArg returns a new RevokeDeviceSessionBatchArg instance +func NewRevokeDeviceSessionBatchArg(RevokeDevices []*RevokeDeviceSessionArg) *RevokeDeviceSessionBatchArg { + s := new(RevokeDeviceSessionBatchArg) + s.RevokeDevices = RevokeDevices + return s +} + +// RevokeDeviceSessionBatchError : +type RevokeDeviceSessionBatchError struct { + dropbox.Tagged +} + +// Valid tag values for RevokeDeviceSessionBatchError +const ( + RevokeDeviceSessionBatchErrorOther = "other" +) + +// RevokeDeviceSessionBatchResult : has no documentation (yet) +type RevokeDeviceSessionBatchResult struct { + // RevokeDevicesStatus : has no documentation (yet) + RevokeDevicesStatus []*RevokeDeviceSessionStatus `json:"revoke_devices_status"` +} + +// NewRevokeDeviceSessionBatchResult returns a new RevokeDeviceSessionBatchResult instance +func NewRevokeDeviceSessionBatchResult(RevokeDevicesStatus []*RevokeDeviceSessionStatus) *RevokeDeviceSessionBatchResult { + s := new(RevokeDeviceSessionBatchResult) + s.RevokeDevicesStatus = RevokeDevicesStatus + return s +} + +// RevokeDeviceSessionError : has no documentation (yet) +type RevokeDeviceSessionError struct { + dropbox.Tagged +} + +// Valid tag values for RevokeDeviceSessionError +const ( + RevokeDeviceSessionErrorDeviceSessionNotFound = "device_session_not_found" + RevokeDeviceSessionErrorMemberNotFound = "member_not_found" + RevokeDeviceSessionErrorOther = "other" +) + +// RevokeDeviceSessionStatus : has no documentation (yet) +type RevokeDeviceSessionStatus struct { + // Success : Result of the revoking request. + Success bool `json:"success"` + // ErrorType : The error cause in case of a failure. + ErrorType *RevokeDeviceSessionError `json:"error_type,omitempty"` +} + +// NewRevokeDeviceSessionStatus returns a new RevokeDeviceSessionStatus instance +func NewRevokeDeviceSessionStatus(Success bool) *RevokeDeviceSessionStatus { + s := new(RevokeDeviceSessionStatus) + s.Success = Success + return s +} + +// RevokeLinkedApiAppArg : has no documentation (yet) +type RevokeLinkedApiAppArg struct { + // AppId : The application's unique id. + AppId string `json:"app_id"` + // TeamMemberId : The unique id of the member owning the device. + TeamMemberId string `json:"team_member_id"` + // KeepAppFolder : Whether to keep the application dedicated folder (in case + // the application uses one). + KeepAppFolder bool `json:"keep_app_folder"` +} + +// NewRevokeLinkedApiAppArg returns a new RevokeLinkedApiAppArg instance +func NewRevokeLinkedApiAppArg(AppId string, TeamMemberId string) *RevokeLinkedApiAppArg { + s := new(RevokeLinkedApiAppArg) + s.AppId = AppId + s.TeamMemberId = TeamMemberId + s.KeepAppFolder = true + return s +} + +// RevokeLinkedApiAppBatchArg : has no documentation (yet) +type RevokeLinkedApiAppBatchArg struct { + // RevokeLinkedApp : has no documentation (yet) + RevokeLinkedApp []*RevokeLinkedApiAppArg `json:"revoke_linked_app"` +} + +// NewRevokeLinkedApiAppBatchArg returns a new RevokeLinkedApiAppBatchArg instance +func NewRevokeLinkedApiAppBatchArg(RevokeLinkedApp []*RevokeLinkedApiAppArg) *RevokeLinkedApiAppBatchArg { + s := new(RevokeLinkedApiAppBatchArg) + s.RevokeLinkedApp = RevokeLinkedApp + return s +} + +// RevokeLinkedAppBatchError : Error returned by +// `linkedAppsRevokeLinkedAppBatch`. +type RevokeLinkedAppBatchError struct { + dropbox.Tagged +} + +// Valid tag values for RevokeLinkedAppBatchError +const ( + RevokeLinkedAppBatchErrorOther = "other" +) + +// RevokeLinkedAppBatchResult : has no documentation (yet) +type RevokeLinkedAppBatchResult struct { + // RevokeLinkedAppStatus : has no documentation (yet) + RevokeLinkedAppStatus []*RevokeLinkedAppStatus `json:"revoke_linked_app_status"` +} + +// NewRevokeLinkedAppBatchResult returns a new RevokeLinkedAppBatchResult instance +func NewRevokeLinkedAppBatchResult(RevokeLinkedAppStatus []*RevokeLinkedAppStatus) *RevokeLinkedAppBatchResult { + s := new(RevokeLinkedAppBatchResult) + s.RevokeLinkedAppStatus = RevokeLinkedAppStatus + return s +} + +// RevokeLinkedAppError : Error returned by `linkedAppsRevokeLinkedApp`. +type RevokeLinkedAppError struct { + dropbox.Tagged +} + +// Valid tag values for RevokeLinkedAppError +const ( + RevokeLinkedAppErrorAppNotFound = "app_not_found" + RevokeLinkedAppErrorMemberNotFound = "member_not_found" + RevokeLinkedAppErrorOther = "other" +) + +// RevokeLinkedAppStatus : has no documentation (yet) +type RevokeLinkedAppStatus struct { + // Success : Result of the revoking request. + Success bool `json:"success"` + // ErrorType : The error cause in case of a failure. + ErrorType *RevokeLinkedAppError `json:"error_type,omitempty"` +} + +// NewRevokeLinkedAppStatus returns a new RevokeLinkedAppStatus instance +func NewRevokeLinkedAppStatus(Success bool) *RevokeLinkedAppStatus { + s := new(RevokeLinkedAppStatus) + s.Success = Success + return s +} + +// SetCustomQuotaArg : has no documentation (yet) +type SetCustomQuotaArg struct { + // UsersAndQuotas : List of users and their custom quotas. + UsersAndQuotas []*UserCustomQuotaArg `json:"users_and_quotas"` +} + +// NewSetCustomQuotaArg returns a new SetCustomQuotaArg instance +func NewSetCustomQuotaArg(UsersAndQuotas []*UserCustomQuotaArg) *SetCustomQuotaArg { + s := new(SetCustomQuotaArg) + s.UsersAndQuotas = UsersAndQuotas + return s +} + +// SetCustomQuotaError : Error returned when setting member custom quota. +type SetCustomQuotaError struct { + dropbox.Tagged +} + +// Valid tag values for SetCustomQuotaError +const ( + SetCustomQuotaErrorTooManyUsers = "too_many_users" + SetCustomQuotaErrorOther = "other" + SetCustomQuotaErrorSomeUsersAreExcluded = "some_users_are_excluded" +) + +// StorageBucket : Describes the number of users in a specific storage bucket. +type StorageBucket struct { + // Bucket : The name of the storage bucket. For example, '1G' is a bucket of + // users with storage size up to 1 Giga. + Bucket string `json:"bucket"` + // Users : The number of people whose storage is in the range of this + // storage bucket. + Users uint64 `json:"users"` +} + +// NewStorageBucket returns a new StorageBucket instance +func NewStorageBucket(Bucket string, Users uint64) *StorageBucket { + s := new(StorageBucket) + s.Bucket = Bucket + s.Users = Users + return s +} + +// TeamFolderAccessError : has no documentation (yet) +type TeamFolderAccessError struct { + dropbox.Tagged +} + +// Valid tag values for TeamFolderAccessError +const ( + TeamFolderAccessErrorInvalidTeamFolderId = "invalid_team_folder_id" + TeamFolderAccessErrorNoAccess = "no_access" + TeamFolderAccessErrorOther = "other" +) + +// TeamFolderActivateError : +type TeamFolderActivateError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` +} + +// Valid tag values for TeamFolderActivateError +const ( + TeamFolderActivateErrorAccessError = "access_error" + TeamFolderActivateErrorStatusError = "status_error" + TeamFolderActivateErrorTeamSharedDropboxError = "team_shared_dropbox_error" + TeamFolderActivateErrorOther = "other" +) + +// UnmarshalJSON deserializes into a TeamFolderActivateError instance +func (u *TeamFolderActivateError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderIdArg : has no documentation (yet) +type TeamFolderIdArg struct { + // TeamFolderId : The ID of the team folder. + TeamFolderId string `json:"team_folder_id"` +} + +// NewTeamFolderIdArg returns a new TeamFolderIdArg instance +func NewTeamFolderIdArg(TeamFolderId string) *TeamFolderIdArg { + s := new(TeamFolderIdArg) + s.TeamFolderId = TeamFolderId + return s +} + +// TeamFolderArchiveArg : has no documentation (yet) +type TeamFolderArchiveArg struct { + TeamFolderIdArg + // ForceAsyncOff : Whether to force the archive to happen synchronously. + ForceAsyncOff bool `json:"force_async_off"` +} + +// NewTeamFolderArchiveArg returns a new TeamFolderArchiveArg instance +func NewTeamFolderArchiveArg(TeamFolderId string) *TeamFolderArchiveArg { + s := new(TeamFolderArchiveArg) + s.TeamFolderId = TeamFolderId + s.ForceAsyncOff = false + return s +} + +// TeamFolderArchiveError : +type TeamFolderArchiveError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` +} + +// Valid tag values for TeamFolderArchiveError +const ( + TeamFolderArchiveErrorAccessError = "access_error" + TeamFolderArchiveErrorStatusError = "status_error" + TeamFolderArchiveErrorTeamSharedDropboxError = "team_shared_dropbox_error" + TeamFolderArchiveErrorOther = "other" +) + +// UnmarshalJSON deserializes into a TeamFolderArchiveError instance +func (u *TeamFolderArchiveError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderArchiveJobStatus : has no documentation (yet) +type TeamFolderArchiveJobStatus struct { + dropbox.Tagged + // Complete : The archive job has finished. The value is the metadata for + // the resulting team folder. + Complete *TeamFolderMetadata `json:"complete,omitempty"` + // Failed : Error occurred while performing an asynchronous job from + // `teamFolderArchive`. + Failed *TeamFolderArchiveError `json:"failed,omitempty"` +} + +// Valid tag values for TeamFolderArchiveJobStatus +const ( + TeamFolderArchiveJobStatusInProgress = "in_progress" + TeamFolderArchiveJobStatusComplete = "complete" + TeamFolderArchiveJobStatusFailed = "failed" +) + +// UnmarshalJSON deserializes into a TeamFolderArchiveJobStatus instance +func (u *TeamFolderArchiveJobStatus) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Complete : The archive job has finished. The value is the metadata + // for the resulting team folder. + Complete json.RawMessage `json:"complete,omitempty"` + // Failed : Error occurred while performing an asynchronous job from + // `teamFolderArchive`. + Failed json.RawMessage `json:"failed,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "complete": + err = json.Unmarshal(body, &u.Complete) + + if err != nil { + return err + } + case "failed": + err = json.Unmarshal(w.Failed, &u.Failed) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderArchiveLaunch : has no documentation (yet) +type TeamFolderArchiveLaunch struct { + dropbox.Tagged + // AsyncJobId : This response indicates that the processing is asynchronous. + // The string is an id that can be used to obtain the status of the + // asynchronous job. + AsyncJobId string `json:"async_job_id,omitempty"` + // Complete : has no documentation (yet) + Complete *TeamFolderMetadata `json:"complete,omitempty"` +} + +// Valid tag values for TeamFolderArchiveLaunch +const ( + TeamFolderArchiveLaunchAsyncJobId = "async_job_id" + TeamFolderArchiveLaunchComplete = "complete" +) + +// UnmarshalJSON deserializes into a TeamFolderArchiveLaunch instance +func (u *TeamFolderArchiveLaunch) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Complete : has no documentation (yet) + Complete json.RawMessage `json:"complete,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "async_job_id": + err = json.Unmarshal(body, &u.AsyncJobId) + + if err != nil { + return err + } + case "complete": + err = json.Unmarshal(body, &u.Complete) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderCreateArg : has no documentation (yet) +type TeamFolderCreateArg struct { + // Name : Name for the new team folder. + Name string `json:"name"` + // SyncSetting : The sync setting to apply to this team folder. Only + // permitted if the team has team selective sync enabled. + SyncSetting *files.SyncSettingArg `json:"sync_setting,omitempty"` +} + +// NewTeamFolderCreateArg returns a new TeamFolderCreateArg instance +func NewTeamFolderCreateArg(Name string) *TeamFolderCreateArg { + s := new(TeamFolderCreateArg) + s.Name = Name + return s +} + +// TeamFolderCreateError : has no documentation (yet) +type TeamFolderCreateError struct { + dropbox.Tagged + // SyncSettingsError : An error occurred setting the sync settings. + SyncSettingsError *files.SyncSettingsError `json:"sync_settings_error,omitempty"` +} + +// Valid tag values for TeamFolderCreateError +const ( + TeamFolderCreateErrorInvalidFolderName = "invalid_folder_name" + TeamFolderCreateErrorFolderNameAlreadyUsed = "folder_name_already_used" + TeamFolderCreateErrorFolderNameReserved = "folder_name_reserved" + TeamFolderCreateErrorSyncSettingsError = "sync_settings_error" + TeamFolderCreateErrorOther = "other" +) + +// UnmarshalJSON deserializes into a TeamFolderCreateError instance +func (u *TeamFolderCreateError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // SyncSettingsError : An error occurred setting the sync settings. + SyncSettingsError json.RawMessage `json:"sync_settings_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "sync_settings_error": + err = json.Unmarshal(w.SyncSettingsError, &u.SyncSettingsError) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderGetInfoItem : has no documentation (yet) +type TeamFolderGetInfoItem struct { + dropbox.Tagged + // IdNotFound : An ID that was provided as a parameter to + // `teamFolderGetInfo` did not match any of the team's team folders. + IdNotFound string `json:"id_not_found,omitempty"` + // TeamFolderMetadata : Properties of a team folder. + TeamFolderMetadata *TeamFolderMetadata `json:"team_folder_metadata,omitempty"` +} + +// Valid tag values for TeamFolderGetInfoItem +const ( + TeamFolderGetInfoItemIdNotFound = "id_not_found" + TeamFolderGetInfoItemTeamFolderMetadata = "team_folder_metadata" +) + +// UnmarshalJSON deserializes into a TeamFolderGetInfoItem instance +func (u *TeamFolderGetInfoItem) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // TeamFolderMetadata : Properties of a team folder. + TeamFolderMetadata json.RawMessage `json:"team_folder_metadata,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "id_not_found": + err = json.Unmarshal(body, &u.IdNotFound) + + if err != nil { + return err + } + case "team_folder_metadata": + err = json.Unmarshal(body, &u.TeamFolderMetadata) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderIdListArg : has no documentation (yet) +type TeamFolderIdListArg struct { + // TeamFolderIds : The list of team folder IDs. + TeamFolderIds []string `json:"team_folder_ids"` +} + +// NewTeamFolderIdListArg returns a new TeamFolderIdListArg instance +func NewTeamFolderIdListArg(TeamFolderIds []string) *TeamFolderIdListArg { + s := new(TeamFolderIdListArg) + s.TeamFolderIds = TeamFolderIds + return s +} + +// TeamFolderInvalidStatusError : has no documentation (yet) +type TeamFolderInvalidStatusError struct { + dropbox.Tagged +} + +// Valid tag values for TeamFolderInvalidStatusError +const ( + TeamFolderInvalidStatusErrorActive = "active" + TeamFolderInvalidStatusErrorArchived = "archived" + TeamFolderInvalidStatusErrorArchiveInProgress = "archive_in_progress" + TeamFolderInvalidStatusErrorOther = "other" +) + +// TeamFolderListArg : has no documentation (yet) +type TeamFolderListArg struct { + // Limit : The maximum number of results to return per request. + Limit uint32 `json:"limit"` +} + +// NewTeamFolderListArg returns a new TeamFolderListArg instance +func NewTeamFolderListArg() *TeamFolderListArg { + s := new(TeamFolderListArg) + s.Limit = 1000 + return s +} + +// TeamFolderListContinueArg : has no documentation (yet) +type TeamFolderListContinueArg struct { + // Cursor : Indicates from what point to get the next set of team folders. + Cursor string `json:"cursor"` +} + +// NewTeamFolderListContinueArg returns a new TeamFolderListContinueArg instance +func NewTeamFolderListContinueArg(Cursor string) *TeamFolderListContinueArg { + s := new(TeamFolderListContinueArg) + s.Cursor = Cursor + return s +} + +// TeamFolderListContinueError : has no documentation (yet) +type TeamFolderListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for TeamFolderListContinueError +const ( + TeamFolderListContinueErrorInvalidCursor = "invalid_cursor" + TeamFolderListContinueErrorOther = "other" +) + +// TeamFolderListError : has no documentation (yet) +type TeamFolderListError struct { + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error"` +} + +// NewTeamFolderListError returns a new TeamFolderListError instance +func NewTeamFolderListError(AccessError *TeamFolderAccessError) *TeamFolderListError { + s := new(TeamFolderListError) + s.AccessError = AccessError + return s +} + +// TeamFolderListResult : Result for `teamFolderList` and +// `teamFolderListContinue`. +type TeamFolderListResult struct { + // TeamFolders : List of all team folders in the authenticated team. + TeamFolders []*TeamFolderMetadata `json:"team_folders"` + // Cursor : Pass the cursor into `teamFolderListContinue` to obtain + // additional team folders. + Cursor string `json:"cursor"` + // HasMore : Is true if there are additional team folders that have not been + // returned yet. An additional call to `teamFolderListContinue` can retrieve + // them. + HasMore bool `json:"has_more"` +} + +// NewTeamFolderListResult returns a new TeamFolderListResult instance +func NewTeamFolderListResult(TeamFolders []*TeamFolderMetadata, Cursor string, HasMore bool) *TeamFolderListResult { + s := new(TeamFolderListResult) + s.TeamFolders = TeamFolders + s.Cursor = Cursor + s.HasMore = HasMore + return s +} + +// TeamFolderMetadata : Properties of a team folder. +type TeamFolderMetadata struct { + // TeamFolderId : The ID of the team folder. + TeamFolderId string `json:"team_folder_id"` + // Name : The name of the team folder. + Name string `json:"name"` + // Status : The status of the team folder. + Status *TeamFolderStatus `json:"status"` + // IsTeamSharedDropbox : True if this team folder is a shared team root. + IsTeamSharedDropbox bool `json:"is_team_shared_dropbox"` + // SyncSetting : The sync setting applied to this team folder. + SyncSetting *files.SyncSetting `json:"sync_setting"` + // ContentSyncSettings : Sync settings applied to contents of this team + // folder. + ContentSyncSettings []*files.ContentSyncSetting `json:"content_sync_settings"` +} + +// NewTeamFolderMetadata returns a new TeamFolderMetadata instance +func NewTeamFolderMetadata(TeamFolderId string, Name string, Status *TeamFolderStatus, IsTeamSharedDropbox bool, SyncSetting *files.SyncSetting, ContentSyncSettings []*files.ContentSyncSetting) *TeamFolderMetadata { + s := new(TeamFolderMetadata) + s.TeamFolderId = TeamFolderId + s.Name = Name + s.Status = Status + s.IsTeamSharedDropbox = IsTeamSharedDropbox + s.SyncSetting = SyncSetting + s.ContentSyncSettings = ContentSyncSettings + return s +} + +// TeamFolderPermanentlyDeleteError : +type TeamFolderPermanentlyDeleteError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` +} + +// Valid tag values for TeamFolderPermanentlyDeleteError +const ( + TeamFolderPermanentlyDeleteErrorAccessError = "access_error" + TeamFolderPermanentlyDeleteErrorStatusError = "status_error" + TeamFolderPermanentlyDeleteErrorTeamSharedDropboxError = "team_shared_dropbox_error" + TeamFolderPermanentlyDeleteErrorOther = "other" +) + +// UnmarshalJSON deserializes into a TeamFolderPermanentlyDeleteError instance +func (u *TeamFolderPermanentlyDeleteError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderRenameArg : has no documentation (yet) +type TeamFolderRenameArg struct { + TeamFolderIdArg + // Name : New team folder name. + Name string `json:"name"` +} + +// NewTeamFolderRenameArg returns a new TeamFolderRenameArg instance +func NewTeamFolderRenameArg(TeamFolderId string, Name string) *TeamFolderRenameArg { + s := new(TeamFolderRenameArg) + s.TeamFolderId = TeamFolderId + s.Name = Name + return s +} + +// TeamFolderRenameError : has no documentation (yet) +type TeamFolderRenameError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` +} + +// Valid tag values for TeamFolderRenameError +const ( + TeamFolderRenameErrorAccessError = "access_error" + TeamFolderRenameErrorStatusError = "status_error" + TeamFolderRenameErrorTeamSharedDropboxError = "team_shared_dropbox_error" + TeamFolderRenameErrorOther = "other" + TeamFolderRenameErrorInvalidFolderName = "invalid_folder_name" + TeamFolderRenameErrorFolderNameAlreadyUsed = "folder_name_already_used" + TeamFolderRenameErrorFolderNameReserved = "folder_name_reserved" +) + +// UnmarshalJSON deserializes into a TeamFolderRenameError instance +func (u *TeamFolderRenameError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + } + return nil +} + +// TeamFolderStatus : has no documentation (yet) +type TeamFolderStatus struct { + dropbox.Tagged +} + +// Valid tag values for TeamFolderStatus +const ( + TeamFolderStatusActive = "active" + TeamFolderStatusArchived = "archived" + TeamFolderStatusArchiveInProgress = "archive_in_progress" + TeamFolderStatusOther = "other" +) + +// TeamFolderTeamSharedDropboxError : has no documentation (yet) +type TeamFolderTeamSharedDropboxError struct { + dropbox.Tagged +} + +// Valid tag values for TeamFolderTeamSharedDropboxError +const ( + TeamFolderTeamSharedDropboxErrorDisallowed = "disallowed" + TeamFolderTeamSharedDropboxErrorOther = "other" +) + +// TeamFolderUpdateSyncSettingsArg : has no documentation (yet) +type TeamFolderUpdateSyncSettingsArg struct { + TeamFolderIdArg + // SyncSetting : Sync setting to apply to the team folder itself. Only + // meaningful if the team folder is not a shared team root. + SyncSetting *files.SyncSettingArg `json:"sync_setting,omitempty"` + // ContentSyncSettings : Sync settings to apply to contents of this team + // folder. + ContentSyncSettings []*files.ContentSyncSettingArg `json:"content_sync_settings,omitempty"` +} + +// NewTeamFolderUpdateSyncSettingsArg returns a new TeamFolderUpdateSyncSettingsArg instance +func NewTeamFolderUpdateSyncSettingsArg(TeamFolderId string) *TeamFolderUpdateSyncSettingsArg { + s := new(TeamFolderUpdateSyncSettingsArg) + s.TeamFolderId = TeamFolderId + return s +} + +// TeamFolderUpdateSyncSettingsError : has no documentation (yet) +type TeamFolderUpdateSyncSettingsError struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError *TeamFolderAccessError `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError *TeamFolderInvalidStatusError `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError *TeamFolderTeamSharedDropboxError `json:"team_shared_dropbox_error,omitempty"` + // SyncSettingsError : An error occurred setting the sync settings. + SyncSettingsError *files.SyncSettingsError `json:"sync_settings_error,omitempty"` +} + +// Valid tag values for TeamFolderUpdateSyncSettingsError +const ( + TeamFolderUpdateSyncSettingsErrorAccessError = "access_error" + TeamFolderUpdateSyncSettingsErrorStatusError = "status_error" + TeamFolderUpdateSyncSettingsErrorTeamSharedDropboxError = "team_shared_dropbox_error" + TeamFolderUpdateSyncSettingsErrorOther = "other" + TeamFolderUpdateSyncSettingsErrorSyncSettingsError = "sync_settings_error" +) + +// UnmarshalJSON deserializes into a TeamFolderUpdateSyncSettingsError instance +func (u *TeamFolderUpdateSyncSettingsError) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // AccessError : has no documentation (yet) + AccessError json.RawMessage `json:"access_error,omitempty"` + // StatusError : has no documentation (yet) + StatusError json.RawMessage `json:"status_error,omitempty"` + // TeamSharedDropboxError : has no documentation (yet) + TeamSharedDropboxError json.RawMessage `json:"team_shared_dropbox_error,omitempty"` + // SyncSettingsError : An error occurred setting the sync settings. + SyncSettingsError json.RawMessage `json:"sync_settings_error,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "access_error": + err = json.Unmarshal(w.AccessError, &u.AccessError) + + if err != nil { + return err + } + case "status_error": + err = json.Unmarshal(w.StatusError, &u.StatusError) + + if err != nil { + return err + } + case "team_shared_dropbox_error": + err = json.Unmarshal(w.TeamSharedDropboxError, &u.TeamSharedDropboxError) + + if err != nil { + return err + } + case "sync_settings_error": + err = json.Unmarshal(w.SyncSettingsError, &u.SyncSettingsError) + + if err != nil { + return err + } + } + return nil +} + +// TeamGetInfoResult : has no documentation (yet) +type TeamGetInfoResult struct { + // Name : The name of the team. + Name string `json:"name"` + // TeamId : The ID of the team. + TeamId string `json:"team_id"` + // NumLicensedUsers : The number of licenses available to the team. + NumLicensedUsers uint32 `json:"num_licensed_users"` + // NumProvisionedUsers : The number of accounts that have been invited or + // are already active members of the team. + NumProvisionedUsers uint32 `json:"num_provisioned_users"` + // Policies : has no documentation (yet) + Policies *team_policies.TeamMemberPolicies `json:"policies"` +} + +// NewTeamGetInfoResult returns a new TeamGetInfoResult instance +func NewTeamGetInfoResult(Name string, TeamId string, NumLicensedUsers uint32, NumProvisionedUsers uint32, Policies *team_policies.TeamMemberPolicies) *TeamGetInfoResult { + s := new(TeamGetInfoResult) + s.Name = Name + s.TeamId = TeamId + s.NumLicensedUsers = NumLicensedUsers + s.NumProvisionedUsers = NumProvisionedUsers + s.Policies = Policies + return s +} + +// TeamMemberInfo : Information about a team member. +type TeamMemberInfo struct { + // Profile : Profile of a user as a member of a team. + Profile *TeamMemberProfile `json:"profile"` + // Role : The user's role in the team. + Role *AdminTier `json:"role"` +} + +// NewTeamMemberInfo returns a new TeamMemberInfo instance +func NewTeamMemberInfo(Profile *TeamMemberProfile, Role *AdminTier) *TeamMemberInfo { + s := new(TeamMemberInfo) + s.Profile = Profile + s.Role = Role + return s +} + +// TeamMemberProfile : Profile of a user as a member of a team. +type TeamMemberProfile struct { + MemberProfile + // Groups : List of group IDs of groups that the user belongs to. + Groups []string `json:"groups"` + // MemberFolderId : The namespace id of the user's root folder. + MemberFolderId string `json:"member_folder_id"` +} + +// NewTeamMemberProfile returns a new TeamMemberProfile instance +func NewTeamMemberProfile(TeamMemberId string, Email string, EmailVerified bool, Status *TeamMemberStatus, Name *users.Name, MembershipType *TeamMembershipType, Groups []string, MemberFolderId string) *TeamMemberProfile { + s := new(TeamMemberProfile) + s.TeamMemberId = TeamMemberId + s.Email = Email + s.EmailVerified = EmailVerified + s.Status = Status + s.Name = Name + s.MembershipType = MembershipType + s.Groups = Groups + s.MemberFolderId = MemberFolderId + return s +} + +// TeamMemberStatus : The user's status as a member of a specific team. +type TeamMemberStatus struct { + dropbox.Tagged + // Removed : User is no longer a member of the team. Removed users are only + // listed when include_removed is true in members/list. + Removed *RemovedStatus `json:"removed,omitempty"` +} + +// Valid tag values for TeamMemberStatus +const ( + TeamMemberStatusActive = "active" + TeamMemberStatusInvited = "invited" + TeamMemberStatusSuspended = "suspended" + TeamMemberStatusRemoved = "removed" +) + +// UnmarshalJSON deserializes into a TeamMemberStatus instance +func (u *TeamMemberStatus) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // Removed : User is no longer a member of the team. Removed users are + // only listed when include_removed is true in members/list. + Removed json.RawMessage `json:"removed,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "removed": + err = json.Unmarshal(body, &u.Removed) + + if err != nil { + return err + } + } + return nil +} + +// TeamMembershipType : has no documentation (yet) +type TeamMembershipType struct { + dropbox.Tagged +} + +// Valid tag values for TeamMembershipType +const ( + TeamMembershipTypeFull = "full" + TeamMembershipTypeLimited = "limited" +) + +// TeamNamespacesListArg : has no documentation (yet) +type TeamNamespacesListArg struct { + // Limit : Specifying a value here has no effect. + Limit uint32 `json:"limit"` +} + +// NewTeamNamespacesListArg returns a new TeamNamespacesListArg instance +func NewTeamNamespacesListArg() *TeamNamespacesListArg { + s := new(TeamNamespacesListArg) + s.Limit = 1000 + return s +} + +// TeamNamespacesListContinueArg : has no documentation (yet) +type TeamNamespacesListContinueArg struct { + // Cursor : Indicates from what point to get the next set of team-accessible + // namespaces. + Cursor string `json:"cursor"` +} + +// NewTeamNamespacesListContinueArg returns a new TeamNamespacesListContinueArg instance +func NewTeamNamespacesListContinueArg(Cursor string) *TeamNamespacesListContinueArg { + s := new(TeamNamespacesListContinueArg) + s.Cursor = Cursor + return s +} + +// TeamNamespacesListContinueError : has no documentation (yet) +type TeamNamespacesListContinueError struct { + dropbox.Tagged +} + +// Valid tag values for TeamNamespacesListContinueError +const ( + TeamNamespacesListContinueErrorInvalidCursor = "invalid_cursor" + TeamNamespacesListContinueErrorOther = "other" +) + +// TeamNamespacesListResult : Result for `namespacesList`. +type TeamNamespacesListResult struct { + // Namespaces : List of all namespaces the team can access. + Namespaces []*NamespaceMetadata `json:"namespaces"` + // Cursor : Pass the cursor into `namespacesListContinue` to obtain + // additional namespaces. Note that duplicate namespaces may be returned. + Cursor string `json:"cursor"` + // HasMore : Is true if there are additional namespaces that have not been + // returned yet. + HasMore bool `json:"has_more"` +} + +// NewTeamNamespacesListResult returns a new TeamNamespacesListResult instance +func NewTeamNamespacesListResult(Namespaces []*NamespaceMetadata, Cursor string, HasMore bool) *TeamNamespacesListResult { + s := new(TeamNamespacesListResult) + s.Namespaces = Namespaces + s.Cursor = Cursor + s.HasMore = HasMore + return s +} + +// TokenGetAuthenticatedAdminError : Error returned by +// `tokenGetAuthenticatedAdmin`. +type TokenGetAuthenticatedAdminError struct { + dropbox.Tagged +} + +// Valid tag values for TokenGetAuthenticatedAdminError +const ( + TokenGetAuthenticatedAdminErrorMappingNotFound = "mapping_not_found" + TokenGetAuthenticatedAdminErrorAdminNotActive = "admin_not_active" + TokenGetAuthenticatedAdminErrorOther = "other" +) + +// TokenGetAuthenticatedAdminResult : Results for `tokenGetAuthenticatedAdmin`. +type TokenGetAuthenticatedAdminResult struct { + // AdminProfile : The admin who authorized the token. + AdminProfile *TeamMemberProfile `json:"admin_profile"` +} + +// NewTokenGetAuthenticatedAdminResult returns a new TokenGetAuthenticatedAdminResult instance +func NewTokenGetAuthenticatedAdminResult(AdminProfile *TeamMemberProfile) *TokenGetAuthenticatedAdminResult { + s := new(TokenGetAuthenticatedAdminResult) + s.AdminProfile = AdminProfile + return s +} + +// UploadApiRateLimitValue : The value for `Feature.upload_api_rate_limit`. +type UploadApiRateLimitValue struct { + dropbox.Tagged + // Limit : The number of upload API calls allowed per month. + Limit uint32 `json:"limit,omitempty"` +} + +// Valid tag values for UploadApiRateLimitValue +const ( + UploadApiRateLimitValueUnlimited = "unlimited" + UploadApiRateLimitValueLimit = "limit" + UploadApiRateLimitValueOther = "other" +) + +// UnmarshalJSON deserializes into a UploadApiRateLimitValue instance +func (u *UploadApiRateLimitValue) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "limit": + err = json.Unmarshal(body, &u.Limit) + + if err != nil { + return err + } + } + return nil +} + +// UserCustomQuotaArg : User and their required custom quota in GB (1 TB = 1024 +// GB). +type UserCustomQuotaArg struct { + // User : has no documentation (yet) + User *UserSelectorArg `json:"user"` + // QuotaGb : has no documentation (yet) + QuotaGb uint32 `json:"quota_gb"` +} + +// NewUserCustomQuotaArg returns a new UserCustomQuotaArg instance +func NewUserCustomQuotaArg(User *UserSelectorArg, QuotaGb uint32) *UserCustomQuotaArg { + s := new(UserCustomQuotaArg) + s.User = User + s.QuotaGb = QuotaGb + return s +} + +// UserCustomQuotaResult : User and their custom quota in GB (1 TB = 1024 GB). +// No quota returns if the user has no custom quota set. +type UserCustomQuotaResult struct { + // User : has no documentation (yet) + User *UserSelectorArg `json:"user"` + // QuotaGb : has no documentation (yet) + QuotaGb uint32 `json:"quota_gb,omitempty"` +} + +// NewUserCustomQuotaResult returns a new UserCustomQuotaResult instance +func NewUserCustomQuotaResult(User *UserSelectorArg) *UserCustomQuotaResult { + s := new(UserCustomQuotaResult) + s.User = User + return s +} + +// UserSelectorArg : Argument for selecting a single user, either by +// team_member_id, external_id or email. +type UserSelectorArg struct { + dropbox.Tagged + // TeamMemberId : has no documentation (yet) + TeamMemberId string `json:"team_member_id,omitempty"` + // ExternalId : has no documentation (yet) + ExternalId string `json:"external_id,omitempty"` + // Email : has no documentation (yet) + Email string `json:"email,omitempty"` +} + +// Valid tag values for UserSelectorArg +const ( + UserSelectorArgTeamMemberId = "team_member_id" + UserSelectorArgExternalId = "external_id" + UserSelectorArgEmail = "email" +) + +// UnmarshalJSON deserializes into a UserSelectorArg instance +func (u *UserSelectorArg) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "team_member_id": + err = json.Unmarshal(body, &u.TeamMemberId) + + if err != nil { + return err + } + case "external_id": + err = json.Unmarshal(body, &u.ExternalId) + + if err != nil { + return err + } + case "email": + err = json.Unmarshal(body, &u.Email) + + if err != nil { + return err + } + } + return nil +} + +// UsersSelectorArg : Argument for selecting a list of users, either by +// team_member_ids, external_ids or emails. +type UsersSelectorArg struct { + dropbox.Tagged + // TeamMemberIds : List of member IDs. + TeamMemberIds []string `json:"team_member_ids,omitempty"` + // ExternalIds : List of external user IDs. + ExternalIds []string `json:"external_ids,omitempty"` + // Emails : List of email addresses. + Emails []string `json:"emails,omitempty"` +} + +// Valid tag values for UsersSelectorArg +const ( + UsersSelectorArgTeamMemberIds = "team_member_ids" + UsersSelectorArgExternalIds = "external_ids" + UsersSelectorArgEmails = "emails" +) + +// UnmarshalJSON deserializes into a UsersSelectorArg instance +func (u *UsersSelectorArg) UnmarshalJSON(body []byte) error { + type wrap struct { + dropbox.Tagged + // TeamMemberIds : List of member IDs. + TeamMemberIds json.RawMessage `json:"team_member_ids,omitempty"` + // ExternalIds : List of external user IDs. + ExternalIds json.RawMessage `json:"external_ids,omitempty"` + // Emails : List of email addresses. + Emails json.RawMessage `json:"emails,omitempty"` + } + var w wrap + var err error + if err = json.Unmarshal(body, &w); err != nil { + return err + } + u.Tag = w.Tag + switch u.Tag { + case "team_member_ids": + err = json.Unmarshal(body, &u.TeamMemberIds) + + if err != nil { + return err + } + case "external_ids": + err = json.Unmarshal(body, &u.ExternalIds) + + if err != nil { + return err + } + case "emails": + err = json.Unmarshal(body, &u.Emails) + + if err != nil { + return err + } + } + return nil +} diff --git a/vendor/modules.txt b/vendor/modules.txt index 991c956a0..55643201d 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -68,6 +68,7 @@ github.com/dropbox/dropbox-sdk-go-unofficial/dropbox github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/common github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/files github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/sharing +github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/team github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/users github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/async github.com/dropbox/dropbox-sdk-go-unofficial/dropbox/file_properties