# -*- coding: utf-8 -*- # Auto-generated by Stone, do not modify. # flake8: noqa # pylint: skip-file """ This namespace contains endpoints and data types for creating and managing shared links and shared folders. """ try: from . import stone_validators as bv from . import stone_base as bb except (SystemError, ValueError): # Catch errors raised when importing a relative module when not in a package. # This makes testing this file directly (outside of a package) easier. import stone_validators as bv import stone_base as bb try: from . import ( async, common, files, team_common, users, users_common, ) except (SystemError, ValueError): import async import common import files import team_common import users import users_common class AccessLevel(bb.Union): """ Defines the access levels for collaborators. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar owner: The collaborator is the owner of the shared folder. Owners can view and edit the shared folder as well as set the folder's policies using :meth:`dropbox.dropbox.Dropbox.sharing_update_folder_policy`. :ivar editor: The collaborator can both view and edit the shared folder. :ivar viewer: The collaborator can only view the shared folder. :ivar viewer_no_comment: The collaborator can only view the shared folder and does not have any access to comments. """ _catch_all = 'other' # Attribute is overwritten below the class definition owner = None # Attribute is overwritten below the class definition editor = None # Attribute is overwritten below the class definition viewer = None # Attribute is overwritten below the class definition viewer_no_comment = None # Attribute is overwritten below the class definition other = None def is_owner(self): """ Check if the union tag is ``owner``. :rtype: bool """ return self._tag == 'owner' def is_editor(self): """ Check if the union tag is ``editor``. :rtype: bool """ return self._tag == 'editor' def is_viewer(self): """ Check if the union tag is ``viewer``. :rtype: bool """ return self._tag == 'viewer' def is_viewer_no_comment(self): """ Check if the union tag is ``viewer_no_comment``. :rtype: bool """ return self._tag == 'viewer_no_comment' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'AccessLevel(%r, %r)' % (self._tag, self._value) AccessLevel_validator = bv.Union(AccessLevel) class AclUpdatePolicy(bb.Union): """ Who can change a shared folder's access control list (ACL). In other words, who can add, remove, or change the privileges of members. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar owner: Only the owner can update the ACL. :ivar editors: Any editor can update the ACL. This may be further restricted to editors on the same team. """ _catch_all = 'other' # Attribute is overwritten below the class definition owner = None # Attribute is overwritten below the class definition editors = None # Attribute is overwritten below the class definition other = None def is_owner(self): """ Check if the union tag is ``owner``. :rtype: bool """ return self._tag == 'owner' def is_editors(self): """ Check if the union tag is ``editors``. :rtype: bool """ return self._tag == 'editors' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'AclUpdatePolicy(%r, %r)' % (self._tag, self._value) AclUpdatePolicy_validator = bv.Union(AclUpdatePolicy) class AddFileMemberArgs(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_add_file_member`. :ivar file: File to which to add members. :ivar members: Members to add. Note that even an email address is given, this may result in a user being directy added to the membership if that email is the user's main account email. :ivar custom_message: Message to send to added members in their invitation. :ivar quiet: Whether added members should be notified via device notifications of their invitation. :ivar access_level: AccessLevel union object, describing what access level we want to give new members. :ivar add_message_as_comment: If the custom message should be added as a comment on the file. """ __slots__ = [ '_file_value', '_file_present', '_members_value', '_members_present', '_custom_message_value', '_custom_message_present', '_quiet_value', '_quiet_present', '_access_level_value', '_access_level_present', '_add_message_as_comment_value', '_add_message_as_comment_present', ] _has_required_fields = True def __init__(self, file=None, members=None, custom_message=None, quiet=None, access_level=None, add_message_as_comment=None): self._file_value = None self._file_present = False self._members_value = None self._members_present = False self._custom_message_value = None self._custom_message_present = False self._quiet_value = None self._quiet_present = False self._access_level_value = None self._access_level_present = False self._add_message_as_comment_value = None self._add_message_as_comment_present = False if file is not None: self.file = file if members is not None: self.members = members if custom_message is not None: self.custom_message = custom_message if quiet is not None: self.quiet = quiet if access_level is not None: self.access_level = access_level if add_message_as_comment is not None: self.add_message_as_comment = add_message_as_comment @property def file(self): """ File to which to add members. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def members(self): """ Members to add. Note that even an email address is given, this may result in a user being directy added to the membership if that email is the user's main account email. :rtype: list of [MemberSelector] """ if self._members_present: return self._members_value else: raise AttributeError("missing required field 'members'") @members.setter def members(self, val): val = self._members_validator.validate(val) self._members_value = val self._members_present = True @members.deleter def members(self): self._members_value = None self._members_present = False @property def custom_message(self): """ Message to send to added members in their invitation. :rtype: str """ if self._custom_message_present: return self._custom_message_value else: return None @custom_message.setter def custom_message(self, val): if val is None: del self.custom_message return val = self._custom_message_validator.validate(val) self._custom_message_value = val self._custom_message_present = True @custom_message.deleter def custom_message(self): self._custom_message_value = None self._custom_message_present = False @property def quiet(self): """ Whether added members should be notified via device notifications of their invitation. :rtype: bool """ if self._quiet_present: return self._quiet_value else: return False @quiet.setter def quiet(self, val): val = self._quiet_validator.validate(val) self._quiet_value = val self._quiet_present = True @quiet.deleter def quiet(self): self._quiet_value = None self._quiet_present = False @property def access_level(self): """ AccessLevel union object, describing what access level we want to give new members. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: return AccessLevel.viewer @access_level.setter def access_level(self, val): self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False @property def add_message_as_comment(self): """ If the custom message should be added as a comment on the file. :rtype: bool """ if self._add_message_as_comment_present: return self._add_message_as_comment_value else: return False @add_message_as_comment.setter def add_message_as_comment(self, val): val = self._add_message_as_comment_validator.validate(val) self._add_message_as_comment_value = val self._add_message_as_comment_present = True @add_message_as_comment.deleter def add_message_as_comment(self): self._add_message_as_comment_value = None self._add_message_as_comment_present = False def __repr__(self): return 'AddFileMemberArgs(file={!r}, members={!r}, custom_message={!r}, quiet={!r}, access_level={!r}, add_message_as_comment={!r})'.format( self._file_value, self._members_value, self._custom_message_value, self._quiet_value, self._access_level_value, self._add_message_as_comment_value, ) AddFileMemberArgs_validator = bv.Struct(AddFileMemberArgs) class AddFileMemberError(bb.Union): """ Errors for :meth:`dropbox.dropbox.Dropbox.sharing_add_file_member`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar rate_limit: The user has reached the rate limit for invitations. :ivar invalid_comment: The custom message did not pass comment permissions checks. """ _catch_all = 'other' # Attribute is overwritten below the class definition rate_limit = None # Attribute is overwritten below the class definition invalid_comment = None # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: AddFileMemberError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: AddFileMemberError """ return cls('access_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_rate_limit(self): """ Check if the union tag is ``rate_limit``. :rtype: bool """ return self._tag == 'rate_limit' def is_invalid_comment(self): """ Check if the union tag is ``invalid_comment``. :rtype: bool """ return self._tag == 'invalid_comment' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'AddFileMemberError(%r, %r)' % (self._tag, self._value) AddFileMemberError_validator = bv.Union(AddFileMemberError) class AddFolderMemberArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar members: The intended list of members to add. Added members will receive invites to join the shared folder. :ivar quiet: Whether added members should be notified via email and device notifications of their invite. :ivar custom_message: Optional message to display to added members in their invitation. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_members_value', '_members_present', '_quiet_value', '_quiet_present', '_custom_message_value', '_custom_message_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, members=None, quiet=None, custom_message=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._members_value = None self._members_present = False self._quiet_value = None self._quiet_present = False self._custom_message_value = None self._custom_message_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if members is not None: self.members = members if quiet is not None: self.quiet = quiet if custom_message is not None: self.custom_message = custom_message @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def members(self): """ The intended list of members to add. Added members will receive invites to join the shared folder. :rtype: list of [AddMember] """ if self._members_present: return self._members_value else: raise AttributeError("missing required field 'members'") @members.setter def members(self, val): val = self._members_validator.validate(val) self._members_value = val self._members_present = True @members.deleter def members(self): self._members_value = None self._members_present = False @property def quiet(self): """ Whether added members should be notified via email and device notifications of their invite. :rtype: bool """ if self._quiet_present: return self._quiet_value else: return False @quiet.setter def quiet(self, val): val = self._quiet_validator.validate(val) self._quiet_value = val self._quiet_present = True @quiet.deleter def quiet(self): self._quiet_value = None self._quiet_present = False @property def custom_message(self): """ Optional message to display to added members in their invitation. :rtype: str """ if self._custom_message_present: return self._custom_message_value else: return None @custom_message.setter def custom_message(self, val): if val is None: del self.custom_message return val = self._custom_message_validator.validate(val) self._custom_message_value = val self._custom_message_present = True @custom_message.deleter def custom_message(self): self._custom_message_value = None self._custom_message_present = False def __repr__(self): return 'AddFolderMemberArg(shared_folder_id={!r}, members={!r}, quiet={!r}, custom_message={!r})'.format( self._shared_folder_id_value, self._members_value, self._quiet_value, self._custom_message_value, ) AddFolderMemberArg_validator = bv.Struct(AddFolderMemberArg) class AddFolderMemberError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar SharedFolderAccessError access_error: Unable to access shared folder. :ivar email_unverified: The current user's e-mail address is unverified. :ivar AddMemberSelectorError bad_member: ``AddFolderMemberArg.members`` contains a bad invitation recipient. :ivar cant_share_outside_team: Your team policy does not allow sharing outside of the team. :ivar long too_many_members: The value is the member limit that was reached. :ivar long too_many_pending_invites: The value is the pending invite limit that was reached. :ivar rate_limit: The current user has hit the limit of invites they can send per day. Try again in 24 hours. :ivar too_many_invitees: The current user is trying to share with too many people at once. :ivar insufficient_plan: The current user's account doesn't support this action. An example of this is when adding a read-only member. This action can only be performed by users that have upgraded to a Pro or Business plan. :ivar team_folder: This action cannot be performed on a team shared folder. :ivar no_permission: The current user does not have permission to perform this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition email_unverified = None # Attribute is overwritten below the class definition cant_share_outside_team = None # Attribute is overwritten below the class definition rate_limit = None # Attribute is overwritten below the class definition too_many_invitees = None # Attribute is overwritten below the class definition insufficient_plan = None # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: AddFolderMemberError """ return cls('access_error', val) @classmethod def bad_member(cls, val): """ Create an instance of this class set to the ``bad_member`` tag with value ``val``. :param AddMemberSelectorError val: :rtype: AddFolderMemberError """ return cls('bad_member', val) @classmethod def too_many_members(cls, val): """ Create an instance of this class set to the ``too_many_members`` tag with value ``val``. :param long val: :rtype: AddFolderMemberError """ return cls('too_many_members', val) @classmethod def too_many_pending_invites(cls, val): """ Create an instance of this class set to the ``too_many_pending_invites`` tag with value ``val``. :param long val: :rtype: AddFolderMemberError """ return cls('too_many_pending_invites', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_email_unverified(self): """ Check if the union tag is ``email_unverified``. :rtype: bool """ return self._tag == 'email_unverified' def is_bad_member(self): """ Check if the union tag is ``bad_member``. :rtype: bool """ return self._tag == 'bad_member' def is_cant_share_outside_team(self): """ Check if the union tag is ``cant_share_outside_team``. :rtype: bool """ return self._tag == 'cant_share_outside_team' def is_too_many_members(self): """ Check if the union tag is ``too_many_members``. :rtype: bool """ return self._tag == 'too_many_members' def is_too_many_pending_invites(self): """ Check if the union tag is ``too_many_pending_invites``. :rtype: bool """ return self._tag == 'too_many_pending_invites' def is_rate_limit(self): """ Check if the union tag is ``rate_limit``. :rtype: bool """ return self._tag == 'rate_limit' def is_too_many_invitees(self): """ Check if the union tag is ``too_many_invitees``. :rtype: bool """ return self._tag == 'too_many_invitees' def is_insufficient_plan(self): """ Check if the union tag is ``insufficient_plan``. :rtype: bool """ return self._tag == 'insufficient_plan' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Unable to access shared folder. Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_bad_member(self): """ ``AddFolderMemberArg.members`` contains a bad invitation recipient. Only call this if :meth:`is_bad_member` is true. :rtype: AddMemberSelectorError """ if not self.is_bad_member(): raise AttributeError("tag 'bad_member' not set") return self._value def get_too_many_members(self): """ The value is the member limit that was reached. Only call this if :meth:`is_too_many_members` is true. :rtype: long """ if not self.is_too_many_members(): raise AttributeError("tag 'too_many_members' not set") return self._value def get_too_many_pending_invites(self): """ The value is the pending invite limit that was reached. Only call this if :meth:`is_too_many_pending_invites` is true. :rtype: long """ if not self.is_too_many_pending_invites(): raise AttributeError("tag 'too_many_pending_invites' not set") return self._value def __repr__(self): return 'AddFolderMemberError(%r, %r)' % (self._tag, self._value) AddFolderMemberError_validator = bv.Union(AddFolderMemberError) class AddMember(object): """ The member and type of access the member should have when added to a shared folder. :ivar member: The member to add to the shared folder. :ivar access_level: The access level to grant ``member`` to the shared folder. ``AccessLevel.owner`` is disallowed. """ __slots__ = [ '_member_value', '_member_present', '_access_level_value', '_access_level_present', ] _has_required_fields = True def __init__(self, member=None, access_level=None): self._member_value = None self._member_present = False self._access_level_value = None self._access_level_present = False if member is not None: self.member = member if access_level is not None: self.access_level = access_level @property def member(self): """ The member to add to the shared folder. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False @property def access_level(self): """ The access level to grant ``member`` to the shared folder. ``AccessLevel.owner`` is disallowed. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: return AccessLevel.viewer @access_level.setter def access_level(self, val): self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False def __repr__(self): return 'AddMember(member={!r}, access_level={!r})'.format( self._member_value, self._access_level_value, ) AddMember_validator = bv.Struct(AddMember) class AddMemberSelectorError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar automatic_group: Automatically created groups can only be added to team folders. :ivar str invalid_dropbox_id: The value is the ID that could not be identified. :ivar str invalid_email: The value is the e-email address that is malformed. :ivar str unverified_dropbox_id: The value is the ID of the Dropbox user with an unverified e-mail address. Invite unverified users by e-mail address instead of by their Dropbox ID. :ivar group_deleted: At least one of the specified groups in ``AddFolderMemberArg.members`` is deleted. :ivar group_not_on_team: Sharing to a group that is not on the current user's team. """ _catch_all = 'other' # Attribute is overwritten below the class definition automatic_group = None # Attribute is overwritten below the class definition group_deleted = None # Attribute is overwritten below the class definition group_not_on_team = None # Attribute is overwritten below the class definition other = None @classmethod def invalid_dropbox_id(cls, val): """ Create an instance of this class set to the ``invalid_dropbox_id`` tag with value ``val``. :param str val: :rtype: AddMemberSelectorError """ return cls('invalid_dropbox_id', val) @classmethod def invalid_email(cls, val): """ Create an instance of this class set to the ``invalid_email`` tag with value ``val``. :param str val: :rtype: AddMemberSelectorError """ return cls('invalid_email', val) @classmethod def unverified_dropbox_id(cls, val): """ Create an instance of this class set to the ``unverified_dropbox_id`` tag with value ``val``. :param str val: :rtype: AddMemberSelectorError """ return cls('unverified_dropbox_id', val) def is_automatic_group(self): """ Check if the union tag is ``automatic_group``. :rtype: bool """ return self._tag == 'automatic_group' def is_invalid_dropbox_id(self): """ Check if the union tag is ``invalid_dropbox_id``. :rtype: bool """ return self._tag == 'invalid_dropbox_id' def is_invalid_email(self): """ Check if the union tag is ``invalid_email``. :rtype: bool """ return self._tag == 'invalid_email' def is_unverified_dropbox_id(self): """ Check if the union tag is ``unverified_dropbox_id``. :rtype: bool """ return self._tag == 'unverified_dropbox_id' def is_group_deleted(self): """ Check if the union tag is ``group_deleted``. :rtype: bool """ return self._tag == 'group_deleted' def is_group_not_on_team(self): """ Check if the union tag is ``group_not_on_team``. :rtype: bool """ return self._tag == 'group_not_on_team' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_invalid_dropbox_id(self): """ The value is the ID that could not be identified. Only call this if :meth:`is_invalid_dropbox_id` is true. :rtype: str """ if not self.is_invalid_dropbox_id(): raise AttributeError("tag 'invalid_dropbox_id' not set") return self._value def get_invalid_email(self): """ The value is the e-email address that is malformed. Only call this if :meth:`is_invalid_email` is true. :rtype: str """ if not self.is_invalid_email(): raise AttributeError("tag 'invalid_email' not set") return self._value def get_unverified_dropbox_id(self): """ The value is the ID of the Dropbox user with an unverified e-mail address. Invite unverified users by e-mail address instead of by their Dropbox ID. Only call this if :meth:`is_unverified_dropbox_id` is true. :rtype: str """ if not self.is_unverified_dropbox_id(): raise AttributeError("tag 'unverified_dropbox_id' not set") return self._value def __repr__(self): return 'AddMemberSelectorError(%r, %r)' % (self._tag, self._value) AddMemberSelectorError_validator = bv.Union(AddMemberSelectorError) class AudienceExceptionContentInfo(object): """ Information about the content that has a link audience different than that of this folder. :ivar name: The name of the content, which is either a file or a folder. """ __slots__ = [ '_name_value', '_name_present', ] _has_required_fields = True def __init__(self, name=None): self._name_value = None self._name_present = False if name is not None: self.name = name @property def name(self): """ The name of the content, which is either a file or a folder. :rtype: str """ if self._name_present: return self._name_value else: raise AttributeError("missing required field 'name'") @name.setter def name(self, val): val = self._name_validator.validate(val) self._name_value = val self._name_present = True @name.deleter def name(self): self._name_value = None self._name_present = False def __repr__(self): return 'AudienceExceptionContentInfo(name={!r})'.format( self._name_value, ) AudienceExceptionContentInfo_validator = bv.Struct(AudienceExceptionContentInfo) class AudienceExceptions(object): """ The total count and truncated list of information of content inside this folder that has a different audience than the link on this folder. This is only returned for folders. :ivar exceptions: A truncated list of some of the content that is an exception. The length of this list could be smaller than the count since it is only a sample but will not be empty as long as count is not 0. """ __slots__ = [ '_count_value', '_count_present', '_exceptions_value', '_exceptions_present', ] _has_required_fields = True def __init__(self, count=None, exceptions=None): self._count_value = None self._count_present = False self._exceptions_value = None self._exceptions_present = False if count is not None: self.count = count if exceptions is not None: self.exceptions = exceptions @property def count(self): """ :rtype: long """ if self._count_present: return self._count_value else: raise AttributeError("missing required field 'count'") @count.setter def count(self, val): val = self._count_validator.validate(val) self._count_value = val self._count_present = True @count.deleter def count(self): self._count_value = None self._count_present = False @property def exceptions(self): """ A truncated list of some of the content that is an exception. The length of this list could be smaller than the count since it is only a sample but will not be empty as long as count is not 0. :rtype: list of [AudienceExceptionContentInfo] """ if self._exceptions_present: return self._exceptions_value else: raise AttributeError("missing required field 'exceptions'") @exceptions.setter def exceptions(self, val): val = self._exceptions_validator.validate(val) self._exceptions_value = val self._exceptions_present = True @exceptions.deleter def exceptions(self): self._exceptions_value = None self._exceptions_present = False def __repr__(self): return 'AudienceExceptions(count={!r}, exceptions={!r})'.format( self._count_value, self._exceptions_value, ) AudienceExceptions_validator = bv.Struct(AudienceExceptions) class AudienceRestrictingSharedFolder(object): """ Information about the shared folder that prevents the link audience for this link from being more restrictive. :ivar shared_folder_id: The ID of the shared folder. :ivar name: The name of the shared folder. :ivar audience: The link audience of the shared folder. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_name_value', '_name_present', '_audience_value', '_audience_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, name=None, audience=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._name_value = None self._name_present = False self._audience_value = None self._audience_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if name is not None: self.name = name if audience is not None: self.audience = audience @property def shared_folder_id(self): """ The ID of the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def name(self): """ The name of the shared folder. :rtype: str """ if self._name_present: return self._name_value else: raise AttributeError("missing required field 'name'") @name.setter def name(self, val): val = self._name_validator.validate(val) self._name_value = val self._name_present = True @name.deleter def name(self): self._name_value = None self._name_present = False @property def audience(self): """ The link audience of the shared folder. :rtype: LinkAudience """ if self._audience_present: return self._audience_value else: raise AttributeError("missing required field 'audience'") @audience.setter def audience(self, val): self._audience_validator.validate_type_only(val) self._audience_value = val self._audience_present = True @audience.deleter def audience(self): self._audience_value = None self._audience_present = False def __repr__(self): return 'AudienceRestrictingSharedFolder(shared_folder_id={!r}, name={!r}, audience={!r})'.format( self._shared_folder_id_value, self._name_value, self._audience_value, ) AudienceRestrictingSharedFolder_validator = bv.Struct(AudienceRestrictingSharedFolder) class ChangeFileMemberAccessArgs(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_change_file_member_access`. :ivar file: File for which we are changing a member's access. :ivar member: The member whose access we are changing. :ivar access_level: The new access level for the member. """ __slots__ = [ '_file_value', '_file_present', '_member_value', '_member_present', '_access_level_value', '_access_level_present', ] _has_required_fields = True def __init__(self, file=None, member=None, access_level=None): self._file_value = None self._file_present = False self._member_value = None self._member_present = False self._access_level_value = None self._access_level_present = False if file is not None: self.file = file if member is not None: self.member = member if access_level is not None: self.access_level = access_level @property def file(self): """ File for which we are changing a member's access. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def member(self): """ The member whose access we are changing. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False @property def access_level(self): """ The new access level for the member. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: raise AttributeError("missing required field 'access_level'") @access_level.setter def access_level(self, val): self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False def __repr__(self): return 'ChangeFileMemberAccessArgs(file={!r}, member={!r}, access_level={!r})'.format( self._file_value, self._member_value, self._access_level_value, ) ChangeFileMemberAccessArgs_validator = bv.Struct(ChangeFileMemberAccessArgs) class LinkMetadata(object): """ Metadata for a shared link. This can be either a :class:`PathLinkMetadata` or :class:`CollectionLinkMetadata`. :ivar url: URL of the shared link. :ivar visibility: Who can access the link. :ivar expires: Expiration time, if set. By default the link won't expire. """ __slots__ = [ '_url_value', '_url_present', '_visibility_value', '_visibility_present', '_expires_value', '_expires_present', ] _has_required_fields = True def __init__(self, url=None, visibility=None, expires=None): self._url_value = None self._url_present = False self._visibility_value = None self._visibility_present = False self._expires_value = None self._expires_present = False if url is not None: self.url = url if visibility is not None: self.visibility = visibility if expires is not None: self.expires = expires @property def url(self): """ URL of the shared link. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False @property def visibility(self): """ Who can access the link. :rtype: Visibility """ if self._visibility_present: return self._visibility_value else: raise AttributeError("missing required field 'visibility'") @visibility.setter def visibility(self, val): self._visibility_validator.validate_type_only(val) self._visibility_value = val self._visibility_present = True @visibility.deleter def visibility(self): self._visibility_value = None self._visibility_present = False @property def expires(self): """ Expiration time, if set. By default the link won't expire. :rtype: datetime.datetime """ if self._expires_present: return self._expires_value else: return None @expires.setter def expires(self, val): if val is None: del self.expires return val = self._expires_validator.validate(val) self._expires_value = val self._expires_present = True @expires.deleter def expires(self): self._expires_value = None self._expires_present = False def __repr__(self): return 'LinkMetadata(url={!r}, visibility={!r}, expires={!r})'.format( self._url_value, self._visibility_value, self._expires_value, ) LinkMetadata_validator = bv.StructTree(LinkMetadata) class CollectionLinkMetadata(LinkMetadata): """ Metadata for a collection-based shared link. """ __slots__ = [ ] _has_required_fields = True def __init__(self, url=None, visibility=None, expires=None): super(CollectionLinkMetadata, self).__init__(url, visibility, expires) def __repr__(self): return 'CollectionLinkMetadata(url={!r}, visibility={!r}, expires={!r})'.format( self._url_value, self._visibility_value, self._expires_value, ) CollectionLinkMetadata_validator = bv.Struct(CollectionLinkMetadata) class CreateSharedLinkArg(object): """ :ivar path: The path to share. :ivar short_url: Whether to return a shortened URL. :ivar pending_upload: If it's okay to share a path that does not yet exist, set this to either ``PendingUploadMode.file`` or ``PendingUploadMode.folder`` to indicate whether to assume it's a file or folder. """ __slots__ = [ '_path_value', '_path_present', '_short_url_value', '_short_url_present', '_pending_upload_value', '_pending_upload_present', ] _has_required_fields = True def __init__(self, path=None, short_url=None, pending_upload=None): self._path_value = None self._path_present = False self._short_url_value = None self._short_url_present = False self._pending_upload_value = None self._pending_upload_present = False if path is not None: self.path = path if short_url is not None: self.short_url = short_url if pending_upload is not None: self.pending_upload = pending_upload @property def path(self): """ The path to share. :rtype: str """ if self._path_present: return self._path_value else: raise AttributeError("missing required field 'path'") @path.setter def path(self, val): val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False @property def short_url(self): """ Whether to return a shortened URL. :rtype: bool """ if self._short_url_present: return self._short_url_value else: return False @short_url.setter def short_url(self, val): val = self._short_url_validator.validate(val) self._short_url_value = val self._short_url_present = True @short_url.deleter def short_url(self): self._short_url_value = None self._short_url_present = False @property def pending_upload(self): """ If it's okay to share a path that does not yet exist, set this to either ``PendingUploadMode.file`` or ``PendingUploadMode.folder`` to indicate whether to assume it's a file or folder. :rtype: PendingUploadMode """ if self._pending_upload_present: return self._pending_upload_value else: return None @pending_upload.setter def pending_upload(self, val): if val is None: del self.pending_upload return self._pending_upload_validator.validate_type_only(val) self._pending_upload_value = val self._pending_upload_present = True @pending_upload.deleter def pending_upload(self): self._pending_upload_value = None self._pending_upload_present = False def __repr__(self): return 'CreateSharedLinkArg(path={!r}, short_url={!r}, pending_upload={!r})'.format( self._path_value, self._short_url_value, self._pending_upload_value, ) CreateSharedLinkArg_validator = bv.Struct(CreateSharedLinkArg) class CreateSharedLinkError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def path(cls, val): """ Create an instance of this class set to the ``path`` tag with value ``val``. :param files.LookupError_validator val: :rtype: CreateSharedLinkError """ return cls('path', val) def is_path(self): """ Check if the union tag is ``path``. :rtype: bool """ return self._tag == 'path' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_path(self): """ Only call this if :meth:`is_path` is true. :rtype: files.LookupError_validator """ if not self.is_path(): raise AttributeError("tag 'path' not set") return self._value def __repr__(self): return 'CreateSharedLinkError(%r, %r)' % (self._tag, self._value) CreateSharedLinkError_validator = bv.Union(CreateSharedLinkError) class CreateSharedLinkWithSettingsArg(object): """ :ivar path: The path to be shared by the shared link. :ivar settings: The requested settings for the newly created shared link. """ __slots__ = [ '_path_value', '_path_present', '_settings_value', '_settings_present', ] _has_required_fields = True def __init__(self, path=None, settings=None): self._path_value = None self._path_present = False self._settings_value = None self._settings_present = False if path is not None: self.path = path if settings is not None: self.settings = settings @property def path(self): """ The path to be shared by the shared link. :rtype: str """ if self._path_present: return self._path_value else: raise AttributeError("missing required field 'path'") @path.setter def path(self, val): val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False @property def settings(self): """ The requested settings for the newly created shared link. :rtype: SharedLinkSettings """ if self._settings_present: return self._settings_value else: return None @settings.setter def settings(self, val): if val is None: del self.settings return self._settings_validator.validate_type_only(val) self._settings_value = val self._settings_present = True @settings.deleter def settings(self): self._settings_value = None self._settings_present = False def __repr__(self): return 'CreateSharedLinkWithSettingsArg(path={!r}, settings={!r})'.format( self._path_value, self._settings_value, ) CreateSharedLinkWithSettingsArg_validator = bv.Struct(CreateSharedLinkWithSettingsArg) class CreateSharedLinkWithSettingsError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar email_not_verified: User's email should be verified. :ivar shared_link_already_exists: The shared link already exists. You can call :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to get the existing link. :ivar SharedLinkSettingsError settings_error: There is an error with the given settings. :ivar access_denied: Access to the requested path is forbidden. """ _catch_all = None # Attribute is overwritten below the class definition email_not_verified = None # Attribute is overwritten below the class definition shared_link_already_exists = None # Attribute is overwritten below the class definition access_denied = None @classmethod def path(cls, val): """ Create an instance of this class set to the ``path`` tag with value ``val``. :param files.LookupError_validator val: :rtype: CreateSharedLinkWithSettingsError """ return cls('path', val) @classmethod def settings_error(cls, val): """ Create an instance of this class set to the ``settings_error`` tag with value ``val``. :param SharedLinkSettingsError val: :rtype: CreateSharedLinkWithSettingsError """ return cls('settings_error', val) def is_path(self): """ Check if the union tag is ``path``. :rtype: bool """ return self._tag == 'path' def is_email_not_verified(self): """ Check if the union tag is ``email_not_verified``. :rtype: bool """ return self._tag == 'email_not_verified' def is_shared_link_already_exists(self): """ Check if the union tag is ``shared_link_already_exists``. :rtype: bool """ return self._tag == 'shared_link_already_exists' def is_settings_error(self): """ Check if the union tag is ``settings_error``. :rtype: bool """ return self._tag == 'settings_error' def is_access_denied(self): """ Check if the union tag is ``access_denied``. :rtype: bool """ return self._tag == 'access_denied' def get_path(self): """ Only call this if :meth:`is_path` is true. :rtype: files.LookupError_validator """ if not self.is_path(): raise AttributeError("tag 'path' not set") return self._value def get_settings_error(self): """ There is an error with the given settings. Only call this if :meth:`is_settings_error` is true. :rtype: SharedLinkSettingsError """ if not self.is_settings_error(): raise AttributeError("tag 'settings_error' not set") return self._value def __repr__(self): return 'CreateSharedLinkWithSettingsError(%r, %r)' % (self._tag, self._value) CreateSharedLinkWithSettingsError_validator = bv.Union(CreateSharedLinkWithSettingsError) class SharedContentLinkMetadataBase(object): """ :ivar access_level: The access level on the link for this file. :ivar audience_options: The audience options that are available for the content. Some audience options may be unavailable. For example, team_only may be unavailable if the content is not owned by a user on a team. The 'default' audience option is always available if the user can modify link settings. :ivar audience_restricting_shared_folder: The shared folder that prevents the link audience for this link from being more restrictive. :ivar current_audience: The current audience of the link. :ivar expiry: Whether the link has an expiry set on it. A link with an expiry will have its audience changed to members when the expiry is reached. :ivar link_permissions: A list of permissions for actions you can perform on the link. :ivar password_protected: Whether the link is protected by a password. """ __slots__ = [ '_access_level_value', '_access_level_present', '_audience_options_value', '_audience_options_present', '_audience_restricting_shared_folder_value', '_audience_restricting_shared_folder_present', '_current_audience_value', '_current_audience_present', '_expiry_value', '_expiry_present', '_link_permissions_value', '_link_permissions_present', '_password_protected_value', '_password_protected_present', ] _has_required_fields = True def __init__(self, audience_options=None, current_audience=None, link_permissions=None, password_protected=None, access_level=None, audience_restricting_shared_folder=None, expiry=None): self._access_level_value = None self._access_level_present = False self._audience_options_value = None self._audience_options_present = False self._audience_restricting_shared_folder_value = None self._audience_restricting_shared_folder_present = False self._current_audience_value = None self._current_audience_present = False self._expiry_value = None self._expiry_present = False self._link_permissions_value = None self._link_permissions_present = False self._password_protected_value = None self._password_protected_present = False if access_level is not None: self.access_level = access_level if audience_options is not None: self.audience_options = audience_options if audience_restricting_shared_folder is not None: self.audience_restricting_shared_folder = audience_restricting_shared_folder if current_audience is not None: self.current_audience = current_audience if expiry is not None: self.expiry = expiry if link_permissions is not None: self.link_permissions = link_permissions if password_protected is not None: self.password_protected = password_protected @property def access_level(self): """ The access level on the link for this file. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: return None @access_level.setter def access_level(self, val): if val is None: del self.access_level return self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False @property def audience_options(self): """ The audience options that are available for the content. Some audience options may be unavailable. For example, team_only may be unavailable if the content is not owned by a user on a team. The 'default' audience option is always available if the user can modify link settings. :rtype: list of [LinkAudience] """ if self._audience_options_present: return self._audience_options_value else: raise AttributeError("missing required field 'audience_options'") @audience_options.setter def audience_options(self, val): val = self._audience_options_validator.validate(val) self._audience_options_value = val self._audience_options_present = True @audience_options.deleter def audience_options(self): self._audience_options_value = None self._audience_options_present = False @property def audience_restricting_shared_folder(self): """ The shared folder that prevents the link audience for this link from being more restrictive. :rtype: AudienceRestrictingSharedFolder """ if self._audience_restricting_shared_folder_present: return self._audience_restricting_shared_folder_value else: return None @audience_restricting_shared_folder.setter def audience_restricting_shared_folder(self, val): if val is None: del self.audience_restricting_shared_folder return self._audience_restricting_shared_folder_validator.validate_type_only(val) self._audience_restricting_shared_folder_value = val self._audience_restricting_shared_folder_present = True @audience_restricting_shared_folder.deleter def audience_restricting_shared_folder(self): self._audience_restricting_shared_folder_value = None self._audience_restricting_shared_folder_present = False @property def current_audience(self): """ The current audience of the link. :rtype: LinkAudience """ if self._current_audience_present: return self._current_audience_value else: raise AttributeError("missing required field 'current_audience'") @current_audience.setter def current_audience(self, val): self._current_audience_validator.validate_type_only(val) self._current_audience_value = val self._current_audience_present = True @current_audience.deleter def current_audience(self): self._current_audience_value = None self._current_audience_present = False @property def expiry(self): """ Whether the link has an expiry set on it. A link with an expiry will have its audience changed to members when the expiry is reached. :rtype: datetime.datetime """ if self._expiry_present: return self._expiry_value else: return None @expiry.setter def expiry(self, val): if val is None: del self.expiry return val = self._expiry_validator.validate(val) self._expiry_value = val self._expiry_present = True @expiry.deleter def expiry(self): self._expiry_value = None self._expiry_present = False @property def link_permissions(self): """ A list of permissions for actions you can perform on the link. :rtype: list of [LinkPermission] """ if self._link_permissions_present: return self._link_permissions_value else: raise AttributeError("missing required field 'link_permissions'") @link_permissions.setter def link_permissions(self, val): val = self._link_permissions_validator.validate(val) self._link_permissions_value = val self._link_permissions_present = True @link_permissions.deleter def link_permissions(self): self._link_permissions_value = None self._link_permissions_present = False @property def password_protected(self): """ Whether the link is protected by a password. :rtype: bool """ if self._password_protected_present: return self._password_protected_value else: raise AttributeError("missing required field 'password_protected'") @password_protected.setter def password_protected(self, val): val = self._password_protected_validator.validate(val) self._password_protected_value = val self._password_protected_present = True @password_protected.deleter def password_protected(self): self._password_protected_value = None self._password_protected_present = False def __repr__(self): return 'SharedContentLinkMetadataBase(audience_options={!r}, current_audience={!r}, link_permissions={!r}, password_protected={!r}, access_level={!r}, audience_restricting_shared_folder={!r}, expiry={!r})'.format( self._audience_options_value, self._current_audience_value, self._link_permissions_value, self._password_protected_value, self._access_level_value, self._audience_restricting_shared_folder_value, self._expiry_value, ) SharedContentLinkMetadataBase_validator = bv.Struct(SharedContentLinkMetadataBase) class ExpectedSharedContentLinkMetadata(SharedContentLinkMetadataBase): """ The expected metadata of a shared link for a file or folder when a link is first created for the content. Absent if the link already exists. """ __slots__ = [ ] _has_required_fields = True def __init__(self, audience_options=None, current_audience=None, link_permissions=None, password_protected=None, access_level=None, audience_restricting_shared_folder=None, expiry=None): super(ExpectedSharedContentLinkMetadata, self).__init__(audience_options, current_audience, link_permissions, password_protected, access_level, audience_restricting_shared_folder, expiry) def __repr__(self): return 'ExpectedSharedContentLinkMetadata(audience_options={!r}, current_audience={!r}, link_permissions={!r}, password_protected={!r}, access_level={!r}, audience_restricting_shared_folder={!r}, expiry={!r})'.format( self._audience_options_value, self._current_audience_value, self._link_permissions_value, self._password_protected_value, self._access_level_value, self._audience_restricting_shared_folder_value, self._expiry_value, ) ExpectedSharedContentLinkMetadata_validator = bv.Struct(ExpectedSharedContentLinkMetadata) class FileAction(bb.Union): """ Sharing actions that may be taken on files. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar disable_viewer_info: Disable viewer information on the file. :ivar edit_contents: Change or edit contents of the file. :ivar enable_viewer_info: Enable viewer information on the file. :ivar invite_viewer: Add a member with view permissions. :ivar invite_viewer_no_comment: Add a member with view permissions but no comment permissions. :ivar unshare: Stop sharing this file. :ivar relinquish_membership: Relinquish one's own membership to the file. :ivar share_link: Use create_link instead. :ivar create_link: Create a shared link to the file. """ _catch_all = 'other' # Attribute is overwritten below the class definition disable_viewer_info = None # Attribute is overwritten below the class definition edit_contents = None # Attribute is overwritten below the class definition enable_viewer_info = None # Attribute is overwritten below the class definition invite_viewer = None # Attribute is overwritten below the class definition invite_viewer_no_comment = None # Attribute is overwritten below the class definition unshare = None # Attribute is overwritten below the class definition relinquish_membership = None # Attribute is overwritten below the class definition share_link = None # Attribute is overwritten below the class definition create_link = None # Attribute is overwritten below the class definition other = None def is_disable_viewer_info(self): """ Check if the union tag is ``disable_viewer_info``. :rtype: bool """ return self._tag == 'disable_viewer_info' def is_edit_contents(self): """ Check if the union tag is ``edit_contents``. :rtype: bool """ return self._tag == 'edit_contents' def is_enable_viewer_info(self): """ Check if the union tag is ``enable_viewer_info``. :rtype: bool """ return self._tag == 'enable_viewer_info' def is_invite_viewer(self): """ Check if the union tag is ``invite_viewer``. :rtype: bool """ return self._tag == 'invite_viewer' def is_invite_viewer_no_comment(self): """ Check if the union tag is ``invite_viewer_no_comment``. :rtype: bool """ return self._tag == 'invite_viewer_no_comment' def is_unshare(self): """ Check if the union tag is ``unshare``. :rtype: bool """ return self._tag == 'unshare' def is_relinquish_membership(self): """ Check if the union tag is ``relinquish_membership``. :rtype: bool """ return self._tag == 'relinquish_membership' def is_share_link(self): """ Check if the union tag is ``share_link``. :rtype: bool """ return self._tag == 'share_link' def is_create_link(self): """ Check if the union tag is ``create_link``. :rtype: bool """ return self._tag == 'create_link' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'FileAction(%r, %r)' % (self._tag, self._value) FileAction_validator = bv.Union(FileAction) class FileErrorResult(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar str file_not_found_error: File specified by id was not found. :ivar str invalid_file_action_error: User does not have permission to take the specified action on the file. :ivar str permission_denied_error: User does not have permission to access file specified by file.Id. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def file_not_found_error(cls, val): """ Create an instance of this class set to the ``file_not_found_error`` tag with value ``val``. :param str val: :rtype: FileErrorResult """ return cls('file_not_found_error', val) @classmethod def invalid_file_action_error(cls, val): """ Create an instance of this class set to the ``invalid_file_action_error`` tag with value ``val``. :param str val: :rtype: FileErrorResult """ return cls('invalid_file_action_error', val) @classmethod def permission_denied_error(cls, val): """ Create an instance of this class set to the ``permission_denied_error`` tag with value ``val``. :param str val: :rtype: FileErrorResult """ return cls('permission_denied_error', val) def is_file_not_found_error(self): """ Check if the union tag is ``file_not_found_error``. :rtype: bool """ return self._tag == 'file_not_found_error' def is_invalid_file_action_error(self): """ Check if the union tag is ``invalid_file_action_error``. :rtype: bool """ return self._tag == 'invalid_file_action_error' def is_permission_denied_error(self): """ Check if the union tag is ``permission_denied_error``. :rtype: bool """ return self._tag == 'permission_denied_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_file_not_found_error(self): """ File specified by id was not found. Only call this if :meth:`is_file_not_found_error` is true. :rtype: str """ if not self.is_file_not_found_error(): raise AttributeError("tag 'file_not_found_error' not set") return self._value def get_invalid_file_action_error(self): """ User does not have permission to take the specified action on the file. Only call this if :meth:`is_invalid_file_action_error` is true. :rtype: str """ if not self.is_invalid_file_action_error(): raise AttributeError("tag 'invalid_file_action_error' not set") return self._value def get_permission_denied_error(self): """ User does not have permission to access file specified by file.Id. Only call this if :meth:`is_permission_denied_error` is true. :rtype: str """ if not self.is_permission_denied_error(): raise AttributeError("tag 'permission_denied_error' not set") return self._value def __repr__(self): return 'FileErrorResult(%r, %r)' % (self._tag, self._value) FileErrorResult_validator = bv.Union(FileErrorResult) class SharedLinkMetadata(object): """ The metadata of a shared link. :ivar url: URL of the shared link. :ivar id: A unique identifier for the linked file. :ivar name: The linked file name (including extension). This never contains a slash. :ivar expires: Expiration time, if set. By default the link won't expire. :ivar path_lower: The lowercased full path in the user's Dropbox. This always starts with a slash. This field will only be present only if the linked file is in the authenticated user's dropbox. :ivar link_permissions: The link's access permissions. :ivar team_member_info: The team membership information of the link's owner. This field will only be present if the link's owner is a team member. :ivar content_owner_team_info: The team information of the content's owner. This field will only be present if the content's owner is a team member and the content's owner team is different from the link's owner team. """ __slots__ = [ '_url_value', '_url_present', '_id_value', '_id_present', '_name_value', '_name_present', '_expires_value', '_expires_present', '_path_lower_value', '_path_lower_present', '_link_permissions_value', '_link_permissions_present', '_team_member_info_value', '_team_member_info_present', '_content_owner_team_info_value', '_content_owner_team_info_present', ] _has_required_fields = True def __init__(self, url=None, name=None, link_permissions=None, id=None, expires=None, path_lower=None, team_member_info=None, content_owner_team_info=None): self._url_value = None self._url_present = False self._id_value = None self._id_present = False self._name_value = None self._name_present = False self._expires_value = None self._expires_present = False self._path_lower_value = None self._path_lower_present = False self._link_permissions_value = None self._link_permissions_present = False self._team_member_info_value = None self._team_member_info_present = False self._content_owner_team_info_value = None self._content_owner_team_info_present = False if url is not None: self.url = url if id is not None: self.id = id if name is not None: self.name = name if expires is not None: self.expires = expires if path_lower is not None: self.path_lower = path_lower if link_permissions is not None: self.link_permissions = link_permissions if team_member_info is not None: self.team_member_info = team_member_info if content_owner_team_info is not None: self.content_owner_team_info = content_owner_team_info @property def url(self): """ URL of the shared link. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False @property def id(self): """ A unique identifier for the linked file. :rtype: str """ if self._id_present: return self._id_value else: return None @id.setter def id(self, val): if val is None: del self.id return val = self._id_validator.validate(val) self._id_value = val self._id_present = True @id.deleter def id(self): self._id_value = None self._id_present = False @property def name(self): """ The linked file name (including extension). This never contains a slash. :rtype: str """ if self._name_present: return self._name_value else: raise AttributeError("missing required field 'name'") @name.setter def name(self, val): val = self._name_validator.validate(val) self._name_value = val self._name_present = True @name.deleter def name(self): self._name_value = None self._name_present = False @property def expires(self): """ Expiration time, if set. By default the link won't expire. :rtype: datetime.datetime """ if self._expires_present: return self._expires_value else: return None @expires.setter def expires(self, val): if val is None: del self.expires return val = self._expires_validator.validate(val) self._expires_value = val self._expires_present = True @expires.deleter def expires(self): self._expires_value = None self._expires_present = False @property def path_lower(self): """ The lowercased full path in the user's Dropbox. This always starts with a slash. This field will only be present only if the linked file is in the authenticated user's dropbox. :rtype: str """ if self._path_lower_present: return self._path_lower_value else: return None @path_lower.setter def path_lower(self, val): if val is None: del self.path_lower return val = self._path_lower_validator.validate(val) self._path_lower_value = val self._path_lower_present = True @path_lower.deleter def path_lower(self): self._path_lower_value = None self._path_lower_present = False @property def link_permissions(self): """ The link's access permissions. :rtype: LinkPermissions """ if self._link_permissions_present: return self._link_permissions_value else: raise AttributeError("missing required field 'link_permissions'") @link_permissions.setter def link_permissions(self, val): self._link_permissions_validator.validate_type_only(val) self._link_permissions_value = val self._link_permissions_present = True @link_permissions.deleter def link_permissions(self): self._link_permissions_value = None self._link_permissions_present = False @property def team_member_info(self): """ The team membership information of the link's owner. This field will only be present if the link's owner is a team member. :rtype: TeamMemberInfo """ if self._team_member_info_present: return self._team_member_info_value else: return None @team_member_info.setter def team_member_info(self, val): if val is None: del self.team_member_info return self._team_member_info_validator.validate_type_only(val) self._team_member_info_value = val self._team_member_info_present = True @team_member_info.deleter def team_member_info(self): self._team_member_info_value = None self._team_member_info_present = False @property def content_owner_team_info(self): """ The team information of the content's owner. This field will only be present if the content's owner is a team member and the content's owner team is different from the link's owner team. :rtype: users.Team_validator """ if self._content_owner_team_info_present: return self._content_owner_team_info_value else: return None @content_owner_team_info.setter def content_owner_team_info(self, val): if val is None: del self.content_owner_team_info return val = self._content_owner_team_info_validator.validate(val) self._content_owner_team_info_value = val self._content_owner_team_info_present = True @content_owner_team_info.deleter def content_owner_team_info(self): self._content_owner_team_info_value = None self._content_owner_team_info_present = False def __repr__(self): return 'SharedLinkMetadata(url={!r}, name={!r}, link_permissions={!r}, id={!r}, expires={!r}, path_lower={!r}, team_member_info={!r}, content_owner_team_info={!r})'.format( self._url_value, self._name_value, self._link_permissions_value, self._id_value, self._expires_value, self._path_lower_value, self._team_member_info_value, self._content_owner_team_info_value, ) SharedLinkMetadata_validator = bv.StructTree(SharedLinkMetadata) class FileLinkMetadata(SharedLinkMetadata): """ The metadata of a file shared link. :ivar client_modified: The modification time set by the desktop client when the file was added to Dropbox. Since this time is not verified (the Dropbox server stores whatever the desktop client sends up), this should only be used for display purposes (such as sorting) and not, for example, to determine if a file has changed or not. :ivar server_modified: The last time the file was modified on Dropbox. :ivar rev: A unique identifier for the current revision of a file. This field is the same rev as elsewhere in the API and can be used to detect changes and avoid conflicts. :ivar size: The file size in bytes. """ __slots__ = [ '_client_modified_value', '_client_modified_present', '_server_modified_value', '_server_modified_present', '_rev_value', '_rev_present', '_size_value', '_size_present', ] _has_required_fields = True def __init__(self, url=None, name=None, link_permissions=None, client_modified=None, server_modified=None, rev=None, size=None, id=None, expires=None, path_lower=None, team_member_info=None, content_owner_team_info=None): super(FileLinkMetadata, self).__init__(url, name, link_permissions, id, expires, path_lower, team_member_info, content_owner_team_info) self._client_modified_value = None self._client_modified_present = False self._server_modified_value = None self._server_modified_present = False self._rev_value = None self._rev_present = False self._size_value = None self._size_present = False if client_modified is not None: self.client_modified = client_modified if server_modified is not None: self.server_modified = server_modified if rev is not None: self.rev = rev if size is not None: self.size = size @property def client_modified(self): """ The modification time set by the desktop client when the file was added to Dropbox. Since this time is not verified (the Dropbox server stores whatever the desktop client sends up), this should only be used for display purposes (such as sorting) and not, for example, to determine if a file has changed or not. :rtype: datetime.datetime """ if self._client_modified_present: return self._client_modified_value else: raise AttributeError("missing required field 'client_modified'") @client_modified.setter def client_modified(self, val): val = self._client_modified_validator.validate(val) self._client_modified_value = val self._client_modified_present = True @client_modified.deleter def client_modified(self): self._client_modified_value = None self._client_modified_present = False @property def server_modified(self): """ The last time the file was modified on Dropbox. :rtype: datetime.datetime """ if self._server_modified_present: return self._server_modified_value else: raise AttributeError("missing required field 'server_modified'") @server_modified.setter def server_modified(self, val): val = self._server_modified_validator.validate(val) self._server_modified_value = val self._server_modified_present = True @server_modified.deleter def server_modified(self): self._server_modified_value = None self._server_modified_present = False @property def rev(self): """ A unique identifier for the current revision of a file. This field is the same rev as elsewhere in the API and can be used to detect changes and avoid conflicts. :rtype: str """ if self._rev_present: return self._rev_value else: raise AttributeError("missing required field 'rev'") @rev.setter def rev(self, val): val = self._rev_validator.validate(val) self._rev_value = val self._rev_present = True @rev.deleter def rev(self): self._rev_value = None self._rev_present = False @property def size(self): """ The file size in bytes. :rtype: long """ if self._size_present: return self._size_value else: raise AttributeError("missing required field 'size'") @size.setter def size(self, val): val = self._size_validator.validate(val) self._size_value = val self._size_present = True @size.deleter def size(self): self._size_value = None self._size_present = False def __repr__(self): return 'FileLinkMetadata(url={!r}, name={!r}, link_permissions={!r}, client_modified={!r}, server_modified={!r}, rev={!r}, size={!r}, id={!r}, expires={!r}, path_lower={!r}, team_member_info={!r}, content_owner_team_info={!r})'.format( self._url_value, self._name_value, self._link_permissions_value, self._client_modified_value, self._server_modified_value, self._rev_value, self._size_value, self._id_value, self._expires_value, self._path_lower_value, self._team_member_info_value, self._content_owner_team_info_value, ) FileLinkMetadata_validator = bv.Struct(FileLinkMetadata) class FileMemberActionError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_member: Specified member was not found. :ivar no_permission: User does not have permission to perform this action on this member. :ivar SharingFileAccessError access_error: Specified file was invalid or user does not have access. :ivar MemberAccessLevelResult no_explicit_access: The action cannot be completed because the target member does not have explicit access to the file. The return value is the access that the member has to the file from a parent folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_member = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: FileMemberActionError """ return cls('access_error', val) @classmethod def no_explicit_access(cls, val): """ Create an instance of this class set to the ``no_explicit_access`` tag with value ``val``. :param MemberAccessLevelResult val: :rtype: FileMemberActionError """ return cls('no_explicit_access', val) def is_invalid_member(self): """ Check if the union tag is ``invalid_member``. :rtype: bool """ return self._tag == 'invalid_member' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_no_explicit_access(self): """ Check if the union tag is ``no_explicit_access``. :rtype: bool """ return self._tag == 'no_explicit_access' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Specified file was invalid or user does not have access. Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_no_explicit_access(self): """ The action cannot be completed because the target member does not have explicit access to the file. The return value is the access that the member has to the file from a parent folder. Only call this if :meth:`is_no_explicit_access` is true. :rtype: MemberAccessLevelResult """ if not self.is_no_explicit_access(): raise AttributeError("tag 'no_explicit_access' not set") return self._value def __repr__(self): return 'FileMemberActionError(%r, %r)' % (self._tag, self._value) FileMemberActionError_validator = bv.Union(FileMemberActionError) class FileMemberActionIndividualResult(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar Optional[AccessLevel] success: Member was successfully removed from this file. If AccessLevel is given, the member still has access via a parent shared folder. :ivar FileMemberActionError member_error: User was not able to perform this action. """ _catch_all = None @classmethod def success(cls, val): """ Create an instance of this class set to the ``success`` tag with value ``val``. :param AccessLevel val: :rtype: FileMemberActionIndividualResult """ return cls('success', val) @classmethod def member_error(cls, val): """ Create an instance of this class set to the ``member_error`` tag with value ``val``. :param FileMemberActionError val: :rtype: FileMemberActionIndividualResult """ return cls('member_error', val) def is_success(self): """ Check if the union tag is ``success``. :rtype: bool """ return self._tag == 'success' def is_member_error(self): """ Check if the union tag is ``member_error``. :rtype: bool """ return self._tag == 'member_error' def get_success(self): """ Member was successfully removed from this file. If AccessLevel is given, the member still has access via a parent shared folder. Only call this if :meth:`is_success` is true. :rtype: AccessLevel """ if not self.is_success(): raise AttributeError("tag 'success' not set") return self._value def get_member_error(self): """ User was not able to perform this action. Only call this if :meth:`is_member_error` is true. :rtype: FileMemberActionError """ if not self.is_member_error(): raise AttributeError("tag 'member_error' not set") return self._value def __repr__(self): return 'FileMemberActionIndividualResult(%r, %r)' % (self._tag, self._value) FileMemberActionIndividualResult_validator = bv.Union(FileMemberActionIndividualResult) class FileMemberActionResult(object): """ Per-member result for :meth:`dropbox.dropbox.Dropbox.sharing_add_file_member` or :meth:`dropbox.dropbox.Dropbox.sharing_change_file_member_access`. :ivar member: One of specified input members. :ivar result: The outcome of the action on this member. """ __slots__ = [ '_member_value', '_member_present', '_result_value', '_result_present', ] _has_required_fields = True def __init__(self, member=None, result=None): self._member_value = None self._member_present = False self._result_value = None self._result_present = False if member is not None: self.member = member if result is not None: self.result = result @property def member(self): """ One of specified input members. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False @property def result(self): """ The outcome of the action on this member. :rtype: FileMemberActionIndividualResult """ if self._result_present: return self._result_value else: raise AttributeError("missing required field 'result'") @result.setter def result(self, val): self._result_validator.validate_type_only(val) self._result_value = val self._result_present = True @result.deleter def result(self): self._result_value = None self._result_present = False def __repr__(self): return 'FileMemberActionResult(member={!r}, result={!r})'.format( self._member_value, self._result_value, ) FileMemberActionResult_validator = bv.Struct(FileMemberActionResult) class FileMemberRemoveActionResult(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar MemberAccessLevelResult success: Member was successfully removed from this file. :ivar FileMemberActionError member_error: User was not able to remove this member. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def success(cls, val): """ Create an instance of this class set to the ``success`` tag with value ``val``. :param MemberAccessLevelResult val: :rtype: FileMemberRemoveActionResult """ return cls('success', val) @classmethod def member_error(cls, val): """ Create an instance of this class set to the ``member_error`` tag with value ``val``. :param FileMemberActionError val: :rtype: FileMemberRemoveActionResult """ return cls('member_error', val) def is_success(self): """ Check if the union tag is ``success``. :rtype: bool """ return self._tag == 'success' def is_member_error(self): """ Check if the union tag is ``member_error``. :rtype: bool """ return self._tag == 'member_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_success(self): """ Member was successfully removed from this file. Only call this if :meth:`is_success` is true. :rtype: MemberAccessLevelResult """ if not self.is_success(): raise AttributeError("tag 'success' not set") return self._value def get_member_error(self): """ User was not able to remove this member. Only call this if :meth:`is_member_error` is true. :rtype: FileMemberActionError """ if not self.is_member_error(): raise AttributeError("tag 'member_error' not set") return self._value def __repr__(self): return 'FileMemberRemoveActionResult(%r, %r)' % (self._tag, self._value) FileMemberRemoveActionResult_validator = bv.Union(FileMemberRemoveActionResult) class FilePermission(object): """ Whether the user is allowed to take the sharing action on the file. :ivar action: The action that the user may wish to take on the file. :ivar allow: True if the user is allowed to take the action. :ivar reason: The reason why the user is denied the permission. Not present if the action is allowed. """ __slots__ = [ '_action_value', '_action_present', '_allow_value', '_allow_present', '_reason_value', '_reason_present', ] _has_required_fields = True def __init__(self, action=None, allow=None, reason=None): self._action_value = None self._action_present = False self._allow_value = None self._allow_present = False self._reason_value = None self._reason_present = False if action is not None: self.action = action if allow is not None: self.allow = allow if reason is not None: self.reason = reason @property def action(self): """ The action that the user may wish to take on the file. :rtype: FileAction """ if self._action_present: return self._action_value else: raise AttributeError("missing required field 'action'") @action.setter def action(self, val): self._action_validator.validate_type_only(val) self._action_value = val self._action_present = True @action.deleter def action(self): self._action_value = None self._action_present = False @property def allow(self): """ True if the user is allowed to take the action. :rtype: bool """ if self._allow_present: return self._allow_value else: raise AttributeError("missing required field 'allow'") @allow.setter def allow(self, val): val = self._allow_validator.validate(val) self._allow_value = val self._allow_present = True @allow.deleter def allow(self): self._allow_value = None self._allow_present = False @property def reason(self): """ The reason why the user is denied the permission. Not present if the action is allowed. :rtype: PermissionDeniedReason """ if self._reason_present: return self._reason_value else: return None @reason.setter def reason(self, val): if val is None: del self.reason return self._reason_validator.validate_type_only(val) self._reason_value = val self._reason_present = True @reason.deleter def reason(self): self._reason_value = None self._reason_present = False def __repr__(self): return 'FilePermission(action={!r}, allow={!r}, reason={!r})'.format( self._action_value, self._allow_value, self._reason_value, ) FilePermission_validator = bv.Struct(FilePermission) class FolderAction(bb.Union): """ Actions that may be taken on shared folders. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar change_options: Change folder options, such as who can be invited to join the folder. :ivar disable_viewer_info: Disable viewer information for this folder. :ivar edit_contents: Change or edit contents of the folder. :ivar enable_viewer_info: Enable viewer information on the folder. :ivar invite_editor: Invite a user or group to join the folder with read and write permission. :ivar invite_viewer: Invite a user or group to join the folder with read permission. :ivar invite_viewer_no_comment: Invite a user or group to join the folder with read permission but no comment permissions. :ivar relinquish_membership: Relinquish one's own membership in the folder. :ivar unmount: Unmount the folder. :ivar unshare: Stop sharing this folder. :ivar leave_a_copy: Keep a copy of the contents upon leaving or being kicked from the folder. :ivar share_link: This action is deprecated. Use create_link instead. :ivar create_link: Create a shared link for folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition change_options = None # Attribute is overwritten below the class definition disable_viewer_info = None # Attribute is overwritten below the class definition edit_contents = None # Attribute is overwritten below the class definition enable_viewer_info = None # Attribute is overwritten below the class definition invite_editor = None # Attribute is overwritten below the class definition invite_viewer = None # Attribute is overwritten below the class definition invite_viewer_no_comment = None # Attribute is overwritten below the class definition relinquish_membership = None # Attribute is overwritten below the class definition unmount = None # Attribute is overwritten below the class definition unshare = None # Attribute is overwritten below the class definition leave_a_copy = None # Attribute is overwritten below the class definition share_link = None # Attribute is overwritten below the class definition create_link = None # Attribute is overwritten below the class definition other = None def is_change_options(self): """ Check if the union tag is ``change_options``. :rtype: bool """ return self._tag == 'change_options' def is_disable_viewer_info(self): """ Check if the union tag is ``disable_viewer_info``. :rtype: bool """ return self._tag == 'disable_viewer_info' def is_edit_contents(self): """ Check if the union tag is ``edit_contents``. :rtype: bool """ return self._tag == 'edit_contents' def is_enable_viewer_info(self): """ Check if the union tag is ``enable_viewer_info``. :rtype: bool """ return self._tag == 'enable_viewer_info' def is_invite_editor(self): """ Check if the union tag is ``invite_editor``. :rtype: bool """ return self._tag == 'invite_editor' def is_invite_viewer(self): """ Check if the union tag is ``invite_viewer``. :rtype: bool """ return self._tag == 'invite_viewer' def is_invite_viewer_no_comment(self): """ Check if the union tag is ``invite_viewer_no_comment``. :rtype: bool """ return self._tag == 'invite_viewer_no_comment' def is_relinquish_membership(self): """ Check if the union tag is ``relinquish_membership``. :rtype: bool """ return self._tag == 'relinquish_membership' def is_unmount(self): """ Check if the union tag is ``unmount``. :rtype: bool """ return self._tag == 'unmount' def is_unshare(self): """ Check if the union tag is ``unshare``. :rtype: bool """ return self._tag == 'unshare' def is_leave_a_copy(self): """ Check if the union tag is ``leave_a_copy``. :rtype: bool """ return self._tag == 'leave_a_copy' def is_share_link(self): """ Check if the union tag is ``share_link``. :rtype: bool """ return self._tag == 'share_link' def is_create_link(self): """ Check if the union tag is ``create_link``. :rtype: bool """ return self._tag == 'create_link' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'FolderAction(%r, %r)' % (self._tag, self._value) FolderAction_validator = bv.Union(FolderAction) class FolderLinkMetadata(SharedLinkMetadata): """ The metadata of a folder shared link. """ __slots__ = [ ] _has_required_fields = True def __init__(self, url=None, name=None, link_permissions=None, id=None, expires=None, path_lower=None, team_member_info=None, content_owner_team_info=None): super(FolderLinkMetadata, self).__init__(url, name, link_permissions, id, expires, path_lower, team_member_info, content_owner_team_info) def __repr__(self): return 'FolderLinkMetadata(url={!r}, name={!r}, link_permissions={!r}, id={!r}, expires={!r}, path_lower={!r}, team_member_info={!r}, content_owner_team_info={!r})'.format( self._url_value, self._name_value, self._link_permissions_value, self._id_value, self._expires_value, self._path_lower_value, self._team_member_info_value, self._content_owner_team_info_value, ) FolderLinkMetadata_validator = bv.Struct(FolderLinkMetadata) class FolderPermission(object): """ Whether the user is allowed to take the action on the shared folder. :ivar action: The action that the user may wish to take on the folder. :ivar allow: True if the user is allowed to take the action. :ivar reason: The reason why the user is denied the permission. Not present if the action is allowed, or if no reason is available. """ __slots__ = [ '_action_value', '_action_present', '_allow_value', '_allow_present', '_reason_value', '_reason_present', ] _has_required_fields = True def __init__(self, action=None, allow=None, reason=None): self._action_value = None self._action_present = False self._allow_value = None self._allow_present = False self._reason_value = None self._reason_present = False if action is not None: self.action = action if allow is not None: self.allow = allow if reason is not None: self.reason = reason @property def action(self): """ The action that the user may wish to take on the folder. :rtype: FolderAction """ if self._action_present: return self._action_value else: raise AttributeError("missing required field 'action'") @action.setter def action(self, val): self._action_validator.validate_type_only(val) self._action_value = val self._action_present = True @action.deleter def action(self): self._action_value = None self._action_present = False @property def allow(self): """ True if the user is allowed to take the action. :rtype: bool """ if self._allow_present: return self._allow_value else: raise AttributeError("missing required field 'allow'") @allow.setter def allow(self, val): val = self._allow_validator.validate(val) self._allow_value = val self._allow_present = True @allow.deleter def allow(self): self._allow_value = None self._allow_present = False @property def reason(self): """ The reason why the user is denied the permission. Not present if the action is allowed, or if no reason is available. :rtype: PermissionDeniedReason """ if self._reason_present: return self._reason_value else: return None @reason.setter def reason(self, val): if val is None: del self.reason return self._reason_validator.validate_type_only(val) self._reason_value = val self._reason_present = True @reason.deleter def reason(self): self._reason_value = None self._reason_present = False def __repr__(self): return 'FolderPermission(action={!r}, allow={!r}, reason={!r})'.format( self._action_value, self._allow_value, self._reason_value, ) FolderPermission_validator = bv.Struct(FolderPermission) class FolderPolicy(object): """ A set of policies governing membership and privileges for a shared folder. :ivar member_policy: Who can be a member of this shared folder, as set on the folder itself. The effective policy may differ from this value if the team-wide policy is more restrictive. Present only if the folder is owned by a team. :ivar resolved_member_policy: Who can be a member of this shared folder, taking into account both the folder and the team-wide policy. This value may differ from that of member_policy if the team-wide policy is more restrictive than the folder policy. Present only if the folder is owned by a team. :ivar acl_update_policy: Who can add and remove members from this shared folder. :ivar shared_link_policy: Who links can be shared with. :ivar viewer_info_policy: Who can enable/disable viewer info for this shared folder. """ __slots__ = [ '_member_policy_value', '_member_policy_present', '_resolved_member_policy_value', '_resolved_member_policy_present', '_acl_update_policy_value', '_acl_update_policy_present', '_shared_link_policy_value', '_shared_link_policy_present', '_viewer_info_policy_value', '_viewer_info_policy_present', ] _has_required_fields = True def __init__(self, acl_update_policy=None, shared_link_policy=None, member_policy=None, resolved_member_policy=None, viewer_info_policy=None): self._member_policy_value = None self._member_policy_present = False self._resolved_member_policy_value = None self._resolved_member_policy_present = False self._acl_update_policy_value = None self._acl_update_policy_present = False self._shared_link_policy_value = None self._shared_link_policy_present = False self._viewer_info_policy_value = None self._viewer_info_policy_present = False if member_policy is not None: self.member_policy = member_policy if resolved_member_policy is not None: self.resolved_member_policy = resolved_member_policy if acl_update_policy is not None: self.acl_update_policy = acl_update_policy if shared_link_policy is not None: self.shared_link_policy = shared_link_policy if viewer_info_policy is not None: self.viewer_info_policy = viewer_info_policy @property def member_policy(self): """ Who can be a member of this shared folder, as set on the folder itself. The effective policy may differ from this value if the team-wide policy is more restrictive. Present only if the folder is owned by a team. :rtype: MemberPolicy """ if self._member_policy_present: return self._member_policy_value else: return None @member_policy.setter def member_policy(self, val): if val is None: del self.member_policy return self._member_policy_validator.validate_type_only(val) self._member_policy_value = val self._member_policy_present = True @member_policy.deleter def member_policy(self): self._member_policy_value = None self._member_policy_present = False @property def resolved_member_policy(self): """ Who can be a member of this shared folder, taking into account both the folder and the team-wide policy. This value may differ from that of member_policy if the team-wide policy is more restrictive than the folder policy. Present only if the folder is owned by a team. :rtype: MemberPolicy """ if self._resolved_member_policy_present: return self._resolved_member_policy_value else: return None @resolved_member_policy.setter def resolved_member_policy(self, val): if val is None: del self.resolved_member_policy return self._resolved_member_policy_validator.validate_type_only(val) self._resolved_member_policy_value = val self._resolved_member_policy_present = True @resolved_member_policy.deleter def resolved_member_policy(self): self._resolved_member_policy_value = None self._resolved_member_policy_present = False @property def acl_update_policy(self): """ Who can add and remove members from this shared folder. :rtype: AclUpdatePolicy """ if self._acl_update_policy_present: return self._acl_update_policy_value else: raise AttributeError("missing required field 'acl_update_policy'") @acl_update_policy.setter def acl_update_policy(self, val): self._acl_update_policy_validator.validate_type_only(val) self._acl_update_policy_value = val self._acl_update_policy_present = True @acl_update_policy.deleter def acl_update_policy(self): self._acl_update_policy_value = None self._acl_update_policy_present = False @property def shared_link_policy(self): """ Who links can be shared with. :rtype: SharedLinkPolicy """ if self._shared_link_policy_present: return self._shared_link_policy_value else: raise AttributeError("missing required field 'shared_link_policy'") @shared_link_policy.setter def shared_link_policy(self, val): self._shared_link_policy_validator.validate_type_only(val) self._shared_link_policy_value = val self._shared_link_policy_present = True @shared_link_policy.deleter def shared_link_policy(self): self._shared_link_policy_value = None self._shared_link_policy_present = False @property def viewer_info_policy(self): """ Who can enable/disable viewer info for this shared folder. :rtype: ViewerInfoPolicy """ if self._viewer_info_policy_present: return self._viewer_info_policy_value else: return None @viewer_info_policy.setter def viewer_info_policy(self, val): if val is None: del self.viewer_info_policy return self._viewer_info_policy_validator.validate_type_only(val) self._viewer_info_policy_value = val self._viewer_info_policy_present = True @viewer_info_policy.deleter def viewer_info_policy(self): self._viewer_info_policy_value = None self._viewer_info_policy_present = False def __repr__(self): return 'FolderPolicy(acl_update_policy={!r}, shared_link_policy={!r}, member_policy={!r}, resolved_member_policy={!r}, viewer_info_policy={!r})'.format( self._acl_update_policy_value, self._shared_link_policy_value, self._member_policy_value, self._resolved_member_policy_value, self._viewer_info_policy_value, ) FolderPolicy_validator = bv.Struct(FolderPolicy) class GetFileMetadataArg(object): """ Arguments of :meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata`. :ivar file: The file to query. :ivar actions: A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. """ __slots__ = [ '_file_value', '_file_present', '_actions_value', '_actions_present', ] _has_required_fields = True def __init__(self, file=None, actions=None): self._file_value = None self._file_present = False self._actions_value = None self._actions_present = False if file is not None: self.file = file if actions is not None: self.actions = actions @property def file(self): """ The file to query. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def actions(self): """ A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. :rtype: list of [FileAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'GetFileMetadataArg(file={!r}, actions={!r})'.format( self._file_value, self._actions_value, ) GetFileMetadataArg_validator = bv.Struct(GetFileMetadataArg) class GetFileMetadataBatchArg(object): """ Arguments of :meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata_batch`. :ivar files: The files to query. :ivar actions: A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. """ __slots__ = [ '_files_value', '_files_present', '_actions_value', '_actions_present', ] _has_required_fields = True def __init__(self, files=None, actions=None): self._files_value = None self._files_present = False self._actions_value = None self._actions_present = False if files is not None: self.files = files if actions is not None: self.actions = actions @property def files(self): """ The files to query. :rtype: list of [str] """ if self._files_present: return self._files_value else: raise AttributeError("missing required field 'files'") @files.setter def files(self, val): val = self._files_validator.validate(val) self._files_value = val self._files_present = True @files.deleter def files(self): self._files_value = None self._files_present = False @property def actions(self): """ A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. :rtype: list of [FileAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'GetFileMetadataBatchArg(files={!r}, actions={!r})'.format( self._files_value, self._actions_value, ) GetFileMetadataBatchArg_validator = bv.Struct(GetFileMetadataBatchArg) class GetFileMetadataBatchResult(object): """ Per file results of :meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata_batch`. :ivar file: This is the input file identifier corresponding to one of ``GetFileMetadataBatchArg.files``. :ivar result: The result for this particular file. """ __slots__ = [ '_file_value', '_file_present', '_result_value', '_result_present', ] _has_required_fields = True def __init__(self, file=None, result=None): self._file_value = None self._file_present = False self._result_value = None self._result_present = False if file is not None: self.file = file if result is not None: self.result = result @property def file(self): """ This is the input file identifier corresponding to one of ``GetFileMetadataBatchArg.files``. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def result(self): """ The result for this particular file. :rtype: GetFileMetadataIndividualResult """ if self._result_present: return self._result_value else: raise AttributeError("missing required field 'result'") @result.setter def result(self, val): self._result_validator.validate_type_only(val) self._result_value = val self._result_present = True @result.deleter def result(self): self._result_value = None self._result_present = False def __repr__(self): return 'GetFileMetadataBatchResult(file={!r}, result={!r})'.format( self._file_value, self._result_value, ) GetFileMetadataBatchResult_validator = bv.Struct(GetFileMetadataBatchResult) class GetFileMetadataError(bb.Union): """ Error result for :meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: GetFileMetadataError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: GetFileMetadataError """ return cls('access_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'GetFileMetadataError(%r, %r)' % (self._tag, self._value) GetFileMetadataError_validator = bv.Union(GetFileMetadataError) class GetFileMetadataIndividualResult(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar SharedFileMetadata metadata: The result for this file if it was successful. :ivar SharingFileAccessError access_error: The result for this file if it was an error. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def metadata(cls, val): """ Create an instance of this class set to the ``metadata`` tag with value ``val``. :param SharedFileMetadata val: :rtype: GetFileMetadataIndividualResult """ return cls('metadata', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: GetFileMetadataIndividualResult """ return cls('access_error', val) def is_metadata(self): """ Check if the union tag is ``metadata``. :rtype: bool """ return self._tag == 'metadata' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_metadata(self): """ The result for this file if it was successful. Only call this if :meth:`is_metadata` is true. :rtype: SharedFileMetadata """ if not self.is_metadata(): raise AttributeError("tag 'metadata' not set") return self._value def get_access_error(self): """ The result for this file if it was an error. Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'GetFileMetadataIndividualResult(%r, %r)' % (self._tag, self._value) GetFileMetadataIndividualResult_validator = bv.Union(GetFileMetadataIndividualResult) class GetMetadataArgs(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar actions: A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_actions_value', '_actions_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, actions=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._actions_value = None self._actions_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if actions is not None: self.actions = actions @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def actions(self): """ A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. :rtype: list of [FolderAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'GetMetadataArgs(shared_folder_id={!r}, actions={!r})'.format( self._shared_folder_id_value, self._actions_value, ) GetMetadataArgs_validator = bv.Struct(GetMetadataArgs) class SharedLinkError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar shared_link_not_found: The shared link wasn't found. :ivar shared_link_access_denied: The caller is not allowed to access this shared link. :ivar unsupported_link_type: This type of link is not supported. """ _catch_all = 'other' # Attribute is overwritten below the class definition shared_link_not_found = None # Attribute is overwritten below the class definition shared_link_access_denied = None # Attribute is overwritten below the class definition unsupported_link_type = None # Attribute is overwritten below the class definition other = None def is_shared_link_not_found(self): """ Check if the union tag is ``shared_link_not_found``. :rtype: bool """ return self._tag == 'shared_link_not_found' def is_shared_link_access_denied(self): """ Check if the union tag is ``shared_link_access_denied``. :rtype: bool """ return self._tag == 'shared_link_access_denied' def is_unsupported_link_type(self): """ Check if the union tag is ``unsupported_link_type``. :rtype: bool """ return self._tag == 'unsupported_link_type' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharedLinkError(%r, %r)' % (self._tag, self._value) SharedLinkError_validator = bv.Union(SharedLinkError) class GetSharedLinkFileError(SharedLinkError): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar shared_link_is_directory: Directories cannot be retrieved by this endpoint. """ # Attribute is overwritten below the class definition shared_link_is_directory = None def is_shared_link_is_directory(self): """ Check if the union tag is ``shared_link_is_directory``. :rtype: bool """ return self._tag == 'shared_link_is_directory' def __repr__(self): return 'GetSharedLinkFileError(%r, %r)' % (self._tag, self._value) GetSharedLinkFileError_validator = bv.Union(GetSharedLinkFileError) class GetSharedLinkMetadataArg(object): """ :ivar url: URL of the shared link. :ivar path: If the shared link is to a folder, this parameter can be used to retrieve the metadata for a specific file or sub-folder in this folder. A relative path should be used. :ivar link_password: If the shared link has a password, this parameter can be used. """ __slots__ = [ '_url_value', '_url_present', '_path_value', '_path_present', '_link_password_value', '_link_password_present', ] _has_required_fields = True def __init__(self, url=None, path=None, link_password=None): self._url_value = None self._url_present = False self._path_value = None self._path_present = False self._link_password_value = None self._link_password_present = False if url is not None: self.url = url if path is not None: self.path = path if link_password is not None: self.link_password = link_password @property def url(self): """ URL of the shared link. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False @property def path(self): """ If the shared link is to a folder, this parameter can be used to retrieve the metadata for a specific file or sub-folder in this folder. A relative path should be used. :rtype: str """ if self._path_present: return self._path_value else: return None @path.setter def path(self, val): if val is None: del self.path return val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False @property def link_password(self): """ If the shared link has a password, this parameter can be used. :rtype: str """ if self._link_password_present: return self._link_password_value else: return None @link_password.setter def link_password(self, val): if val is None: del self.link_password return val = self._link_password_validator.validate(val) self._link_password_value = val self._link_password_present = True @link_password.deleter def link_password(self): self._link_password_value = None self._link_password_present = False def __repr__(self): return 'GetSharedLinkMetadataArg(url={!r}, path={!r}, link_password={!r})'.format( self._url_value, self._path_value, self._link_password_value, ) GetSharedLinkMetadataArg_validator = bv.Struct(GetSharedLinkMetadataArg) class GetSharedLinksArg(object): """ :ivar path: See :meth:`dropbox.dropbox.Dropbox.sharing_get_shared_links` description. """ __slots__ = [ '_path_value', '_path_present', ] _has_required_fields = False def __init__(self, path=None): self._path_value = None self._path_present = False if path is not None: self.path = path @property def path(self): """ See :meth:`dropbox.dropbox.Dropbox.sharing_get_shared_links` description. :rtype: str """ if self._path_present: return self._path_value else: return None @path.setter def path(self, val): if val is None: del self.path return val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False def __repr__(self): return 'GetSharedLinksArg(path={!r})'.format( self._path_value, ) GetSharedLinksArg_validator = bv.Struct(GetSharedLinksArg) class GetSharedLinksError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def path(cls, val): """ Create an instance of this class set to the ``path`` tag with value ``val``. :param Optional[str] val: :rtype: GetSharedLinksError """ return cls('path', val) def is_path(self): """ Check if the union tag is ``path``. :rtype: bool """ return self._tag == 'path' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_path(self): """ Only call this if :meth:`is_path` is true. :rtype: Optional[str] """ if not self.is_path(): raise AttributeError("tag 'path' not set") return self._value def __repr__(self): return 'GetSharedLinksError(%r, %r)' % (self._tag, self._value) GetSharedLinksError_validator = bv.Union(GetSharedLinksError) class GetSharedLinksResult(object): """ :ivar links: Shared links applicable to the path argument. """ __slots__ = [ '_links_value', '_links_present', ] _has_required_fields = True def __init__(self, links=None): self._links_value = None self._links_present = False if links is not None: self.links = links @property def links(self): """ Shared links applicable to the path argument. :rtype: list of [LinkMetadata] """ if self._links_present: return self._links_value else: raise AttributeError("missing required field 'links'") @links.setter def links(self, val): val = self._links_validator.validate(val) self._links_value = val self._links_present = True @links.deleter def links(self): self._links_value = None self._links_present = False def __repr__(self): return 'GetSharedLinksResult(links={!r})'.format( self._links_value, ) GetSharedLinksResult_validator = bv.Struct(GetSharedLinksResult) class GroupInfo(team_common.GroupSummary): """ The information about a group. Groups is a way to manage a list of users who need same access permission to the shared folder. :ivar group_type: The type of group. :ivar is_member: If the current user is a member of the group. :ivar is_owner: If the current user is an owner of the group. :ivar same_team: If the group is owned by the current user's team. """ __slots__ = [ '_group_type_value', '_group_type_present', '_is_member_value', '_is_member_present', '_is_owner_value', '_is_owner_present', '_same_team_value', '_same_team_present', ] _has_required_fields = True def __init__(self, group_name=None, group_id=None, group_management_type=None, group_type=None, is_member=None, is_owner=None, same_team=None, group_external_id=None, member_count=None): super(GroupInfo, self).__init__(group_name, group_id, group_management_type, group_external_id, member_count) self._group_type_value = None self._group_type_present = False self._is_member_value = None self._is_member_present = False self._is_owner_value = None self._is_owner_present = False self._same_team_value = None self._same_team_present = False if group_type is not None: self.group_type = group_type if is_member is not None: self.is_member = is_member if is_owner is not None: self.is_owner = is_owner if same_team is not None: self.same_team = same_team @property def group_type(self): """ The type of group. :rtype: team_common.GroupType_validator """ if self._group_type_present: return self._group_type_value else: raise AttributeError("missing required field 'group_type'") @group_type.setter def group_type(self, val): self._group_type_validator.validate_type_only(val) self._group_type_value = val self._group_type_present = True @group_type.deleter def group_type(self): self._group_type_value = None self._group_type_present = False @property def is_member(self): """ If the current user is a member of the group. :rtype: bool """ if self._is_member_present: return self._is_member_value else: raise AttributeError("missing required field 'is_member'") @is_member.setter def is_member(self, val): val = self._is_member_validator.validate(val) self._is_member_value = val self._is_member_present = True @is_member.deleter def is_member(self): self._is_member_value = None self._is_member_present = False @property def is_owner(self): """ If the current user is an owner of the group. :rtype: bool """ if self._is_owner_present: return self._is_owner_value else: raise AttributeError("missing required field 'is_owner'") @is_owner.setter def is_owner(self, val): val = self._is_owner_validator.validate(val) self._is_owner_value = val self._is_owner_present = True @is_owner.deleter def is_owner(self): self._is_owner_value = None self._is_owner_present = False @property def same_team(self): """ If the group is owned by the current user's team. :rtype: bool """ if self._same_team_present: return self._same_team_value else: raise AttributeError("missing required field 'same_team'") @same_team.setter def same_team(self, val): val = self._same_team_validator.validate(val) self._same_team_value = val self._same_team_present = True @same_team.deleter def same_team(self): self._same_team_value = None self._same_team_present = False def __repr__(self): return 'GroupInfo(group_name={!r}, group_id={!r}, group_management_type={!r}, group_type={!r}, is_member={!r}, is_owner={!r}, same_team={!r}, group_external_id={!r}, member_count={!r})'.format( self._group_name_value, self._group_id_value, self._group_management_type_value, self._group_type_value, self._is_member_value, self._is_owner_value, self._same_team_value, self._group_external_id_value, self._member_count_value, ) GroupInfo_validator = bv.Struct(GroupInfo) class MembershipInfo(object): """ The information about a member of the shared content. :ivar access_type: The access type for this member. :ivar permissions: The permissions that requesting user has on this member. The set of permissions corresponds to the MemberActions in the request. :ivar initials: Suggested name initials for a member. :ivar is_inherited: True if the member has access from a parent folder. """ __slots__ = [ '_access_type_value', '_access_type_present', '_permissions_value', '_permissions_present', '_initials_value', '_initials_present', '_is_inherited_value', '_is_inherited_present', ] _has_required_fields = True def __init__(self, access_type=None, permissions=None, initials=None, is_inherited=None): self._access_type_value = None self._access_type_present = False self._permissions_value = None self._permissions_present = False self._initials_value = None self._initials_present = False self._is_inherited_value = None self._is_inherited_present = False if access_type is not None: self.access_type = access_type if permissions is not None: self.permissions = permissions if initials is not None: self.initials = initials if is_inherited is not None: self.is_inherited = is_inherited @property def access_type(self): """ The access type for this member. :rtype: AccessLevel """ if self._access_type_present: return self._access_type_value else: raise AttributeError("missing required field 'access_type'") @access_type.setter def access_type(self, val): self._access_type_validator.validate_type_only(val) self._access_type_value = val self._access_type_present = True @access_type.deleter def access_type(self): self._access_type_value = None self._access_type_present = False @property def permissions(self): """ The permissions that requesting user has on this member. The set of permissions corresponds to the MemberActions in the request. :rtype: list of [MemberPermission] """ if self._permissions_present: return self._permissions_value else: return None @permissions.setter def permissions(self, val): if val is None: del self.permissions return val = self._permissions_validator.validate(val) self._permissions_value = val self._permissions_present = True @permissions.deleter def permissions(self): self._permissions_value = None self._permissions_present = False @property def initials(self): """ Suggested name initials for a member. :rtype: str """ if self._initials_present: return self._initials_value else: return None @initials.setter def initials(self, val): if val is None: del self.initials return val = self._initials_validator.validate(val) self._initials_value = val self._initials_present = True @initials.deleter def initials(self): self._initials_value = None self._initials_present = False @property def is_inherited(self): """ True if the member has access from a parent folder. :rtype: bool """ if self._is_inherited_present: return self._is_inherited_value else: return False @is_inherited.setter def is_inherited(self, val): val = self._is_inherited_validator.validate(val) self._is_inherited_value = val self._is_inherited_present = True @is_inherited.deleter def is_inherited(self): self._is_inherited_value = None self._is_inherited_present = False def __repr__(self): return 'MembershipInfo(access_type={!r}, permissions={!r}, initials={!r}, is_inherited={!r})'.format( self._access_type_value, self._permissions_value, self._initials_value, self._is_inherited_value, ) MembershipInfo_validator = bv.Struct(MembershipInfo) class GroupMembershipInfo(MembershipInfo): """ The information about a group member of the shared content. :ivar group: The information about the membership group. """ __slots__ = [ '_group_value', '_group_present', ] _has_required_fields = True def __init__(self, access_type=None, group=None, permissions=None, initials=None, is_inherited=None): super(GroupMembershipInfo, self).__init__(access_type, permissions, initials, is_inherited) self._group_value = None self._group_present = False if group is not None: self.group = group @property def group(self): """ The information about the membership group. :rtype: GroupInfo """ if self._group_present: return self._group_value else: raise AttributeError("missing required field 'group'") @group.setter def group(self, val): self._group_validator.validate_type_only(val) self._group_value = val self._group_present = True @group.deleter def group(self): self._group_value = None self._group_present = False def __repr__(self): return 'GroupMembershipInfo(access_type={!r}, group={!r}, permissions={!r}, initials={!r}, is_inherited={!r})'.format( self._access_type_value, self._group_value, self._permissions_value, self._initials_value, self._is_inherited_value, ) GroupMembershipInfo_validator = bv.Struct(GroupMembershipInfo) class InsufficientPlan(object): """ :ivar message: A message to tell the user to upgrade in order to support expected action. :ivar upsell_url: A URL to send the user to in order to obtain the account type they need, e.g. upgrading. Absent if there is no action the user can take to upgrade. """ __slots__ = [ '_message_value', '_message_present', '_upsell_url_value', '_upsell_url_present', ] _has_required_fields = True def __init__(self, message=None, upsell_url=None): self._message_value = None self._message_present = False self._upsell_url_value = None self._upsell_url_present = False if message is not None: self.message = message if upsell_url is not None: self.upsell_url = upsell_url @property def message(self): """ A message to tell the user to upgrade in order to support expected action. :rtype: str """ if self._message_present: return self._message_value else: raise AttributeError("missing required field 'message'") @message.setter def message(self, val): val = self._message_validator.validate(val) self._message_value = val self._message_present = True @message.deleter def message(self): self._message_value = None self._message_present = False @property def upsell_url(self): """ A URL to send the user to in order to obtain the account type they need, e.g. upgrading. Absent if there is no action the user can take to upgrade. :rtype: str """ if self._upsell_url_present: return self._upsell_url_value else: return None @upsell_url.setter def upsell_url(self, val): if val is None: del self.upsell_url return val = self._upsell_url_validator.validate(val) self._upsell_url_value = val self._upsell_url_present = True @upsell_url.deleter def upsell_url(self): self._upsell_url_value = None self._upsell_url_present = False def __repr__(self): return 'InsufficientPlan(message={!r}, upsell_url={!r})'.format( self._message_value, self._upsell_url_value, ) InsufficientPlan_validator = bv.Struct(InsufficientPlan) class InsufficientQuotaAmounts(object): """ :ivar space_needed: The amount of space needed to add the item (the size of the item). :ivar space_shortage: The amount of extra space needed to add the item. :ivar space_left: The amount of space left in the user's Dropbox, less than space_needed. """ __slots__ = [ '_space_needed_value', '_space_needed_present', '_space_shortage_value', '_space_shortage_present', '_space_left_value', '_space_left_present', ] _has_required_fields = True def __init__(self, space_needed=None, space_shortage=None, space_left=None): self._space_needed_value = None self._space_needed_present = False self._space_shortage_value = None self._space_shortage_present = False self._space_left_value = None self._space_left_present = False if space_needed is not None: self.space_needed = space_needed if space_shortage is not None: self.space_shortage = space_shortage if space_left is not None: self.space_left = space_left @property def space_needed(self): """ The amount of space needed to add the item (the size of the item). :rtype: long """ if self._space_needed_present: return self._space_needed_value else: raise AttributeError("missing required field 'space_needed'") @space_needed.setter def space_needed(self, val): val = self._space_needed_validator.validate(val) self._space_needed_value = val self._space_needed_present = True @space_needed.deleter def space_needed(self): self._space_needed_value = None self._space_needed_present = False @property def space_shortage(self): """ The amount of extra space needed to add the item. :rtype: long """ if self._space_shortage_present: return self._space_shortage_value else: raise AttributeError("missing required field 'space_shortage'") @space_shortage.setter def space_shortage(self, val): val = self._space_shortage_validator.validate(val) self._space_shortage_value = val self._space_shortage_present = True @space_shortage.deleter def space_shortage(self): self._space_shortage_value = None self._space_shortage_present = False @property def space_left(self): """ The amount of space left in the user's Dropbox, less than space_needed. :rtype: long """ if self._space_left_present: return self._space_left_value else: raise AttributeError("missing required field 'space_left'") @space_left.setter def space_left(self, val): val = self._space_left_validator.validate(val) self._space_left_value = val self._space_left_present = True @space_left.deleter def space_left(self): self._space_left_value = None self._space_left_present = False def __repr__(self): return 'InsufficientQuotaAmounts(space_needed={!r}, space_shortage={!r}, space_left={!r})'.format( self._space_needed_value, self._space_shortage_value, self._space_left_value, ) InsufficientQuotaAmounts_validator = bv.Struct(InsufficientQuotaAmounts) class InviteeInfo(bb.Union): """ Information about the recipient of a shared content invitation. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar str email: E-mail address of invited user. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def email(cls, val): """ Create an instance of this class set to the ``email`` tag with value ``val``. :param str val: :rtype: InviteeInfo """ return cls('email', val) def is_email(self): """ Check if the union tag is ``email``. :rtype: bool """ return self._tag == 'email' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_email(self): """ E-mail address of invited user. Only call this if :meth:`is_email` is true. :rtype: str """ if not self.is_email(): raise AttributeError("tag 'email' not set") return self._value def __repr__(self): return 'InviteeInfo(%r, %r)' % (self._tag, self._value) InviteeInfo_validator = bv.Union(InviteeInfo) class InviteeMembershipInfo(MembershipInfo): """ Information about an invited member of a shared content. :ivar invitee: Recipient of the invitation. :ivar user: The user this invitation is tied to, if available. """ __slots__ = [ '_invitee_value', '_invitee_present', '_user_value', '_user_present', ] _has_required_fields = True def __init__(self, access_type=None, invitee=None, permissions=None, initials=None, is_inherited=None, user=None): super(InviteeMembershipInfo, self).__init__(access_type, permissions, initials, is_inherited) self._invitee_value = None self._invitee_present = False self._user_value = None self._user_present = False if invitee is not None: self.invitee = invitee if user is not None: self.user = user @property def invitee(self): """ Recipient of the invitation. :rtype: InviteeInfo """ if self._invitee_present: return self._invitee_value else: raise AttributeError("missing required field 'invitee'") @invitee.setter def invitee(self, val): self._invitee_validator.validate_type_only(val) self._invitee_value = val self._invitee_present = True @invitee.deleter def invitee(self): self._invitee_value = None self._invitee_present = False @property def user(self): """ The user this invitation is tied to, if available. :rtype: UserInfo """ if self._user_present: return self._user_value else: return None @user.setter def user(self, val): if val is None: del self.user return self._user_validator.validate_type_only(val) self._user_value = val self._user_present = True @user.deleter def user(self): self._user_value = None self._user_present = False def __repr__(self): return 'InviteeMembershipInfo(access_type={!r}, invitee={!r}, permissions={!r}, initials={!r}, is_inherited={!r}, user={!r})'.format( self._access_type_value, self._invitee_value, self._permissions_value, self._initials_value, self._is_inherited_value, self._user_value, ) InviteeMembershipInfo_validator = bv.Struct(InviteeMembershipInfo) class JobError(bb.Union): """ Error occurred while performing an asynchronous job from :meth:`dropbox.dropbox.Dropbox.sharing_unshare_folder` or :meth:`dropbox.dropbox.Dropbox.sharing_remove_folder_member`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar UnshareFolderError unshare_folder_error: Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_unshare_folder` action. :ivar RemoveFolderMemberError remove_folder_member_error: Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_remove_folder_member` action. :ivar RelinquishFolderMembershipError relinquish_folder_membership_error: Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_relinquish_folder_membership` action. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def unshare_folder_error(cls, val): """ Create an instance of this class set to the ``unshare_folder_error`` tag with value ``val``. :param UnshareFolderError val: :rtype: JobError """ return cls('unshare_folder_error', val) @classmethod def remove_folder_member_error(cls, val): """ Create an instance of this class set to the ``remove_folder_member_error`` tag with value ``val``. :param RemoveFolderMemberError val: :rtype: JobError """ return cls('remove_folder_member_error', val) @classmethod def relinquish_folder_membership_error(cls, val): """ Create an instance of this class set to the ``relinquish_folder_membership_error`` tag with value ``val``. :param RelinquishFolderMembershipError val: :rtype: JobError """ return cls('relinquish_folder_membership_error', val) def is_unshare_folder_error(self): """ Check if the union tag is ``unshare_folder_error``. :rtype: bool """ return self._tag == 'unshare_folder_error' def is_remove_folder_member_error(self): """ Check if the union tag is ``remove_folder_member_error``. :rtype: bool """ return self._tag == 'remove_folder_member_error' def is_relinquish_folder_membership_error(self): """ Check if the union tag is ``relinquish_folder_membership_error``. :rtype: bool """ return self._tag == 'relinquish_folder_membership_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_unshare_folder_error(self): """ Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_unshare_folder` action. Only call this if :meth:`is_unshare_folder_error` is true. :rtype: UnshareFolderError """ if not self.is_unshare_folder_error(): raise AttributeError("tag 'unshare_folder_error' not set") return self._value def get_remove_folder_member_error(self): """ Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_remove_folder_member` action. Only call this if :meth:`is_remove_folder_member_error` is true. :rtype: RemoveFolderMemberError """ if not self.is_remove_folder_member_error(): raise AttributeError("tag 'remove_folder_member_error' not set") return self._value def get_relinquish_folder_membership_error(self): """ Error occurred while performing :meth:`dropbox.dropbox.Dropbox.sharing_relinquish_folder_membership` action. Only call this if :meth:`is_relinquish_folder_membership_error` is true. :rtype: RelinquishFolderMembershipError """ if not self.is_relinquish_folder_membership_error(): raise AttributeError("tag 'relinquish_folder_membership_error' not set") return self._value def __repr__(self): return 'JobError(%r, %r)' % (self._tag, self._value) JobError_validator = bv.Union(JobError) class JobStatus(async.PollResultBase): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar complete: The asynchronous job has finished. :ivar JobError failed: The asynchronous job returned an error. """ # Attribute is overwritten below the class definition complete = None @classmethod def failed(cls, val): """ Create an instance of this class set to the ``failed`` tag with value ``val``. :param JobError val: :rtype: JobStatus """ return cls('failed', val) def is_complete(self): """ Check if the union tag is ``complete``. :rtype: bool """ return self._tag == 'complete' def is_failed(self): """ Check if the union tag is ``failed``. :rtype: bool """ return self._tag == 'failed' def get_failed(self): """ The asynchronous job returned an error. Only call this if :meth:`is_failed` is true. :rtype: JobError """ if not self.is_failed(): raise AttributeError("tag 'failed' not set") return self._value def __repr__(self): return 'JobStatus(%r, %r)' % (self._tag, self._value) JobStatus_validator = bv.Union(JobStatus) class LinkAction(bb.Union): """ Actions that can be performed on a link. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar change_access_level: Change the access level of the link. :ivar change_audience: Change the audience of the link. :ivar remove_expiry: Remove the expiry date of the link. :ivar remove_password: Remove the password of the link. :ivar set_expiry: Create or modify the expiry date of the link. :ivar set_password: Create or modify the password of the link. """ _catch_all = 'other' # Attribute is overwritten below the class definition change_access_level = None # Attribute is overwritten below the class definition change_audience = None # Attribute is overwritten below the class definition remove_expiry = None # Attribute is overwritten below the class definition remove_password = None # Attribute is overwritten below the class definition set_expiry = None # Attribute is overwritten below the class definition set_password = None # Attribute is overwritten below the class definition other = None def is_change_access_level(self): """ Check if the union tag is ``change_access_level``. :rtype: bool """ return self._tag == 'change_access_level' def is_change_audience(self): """ Check if the union tag is ``change_audience``. :rtype: bool """ return self._tag == 'change_audience' def is_remove_expiry(self): """ Check if the union tag is ``remove_expiry``. :rtype: bool """ return self._tag == 'remove_expiry' def is_remove_password(self): """ Check if the union tag is ``remove_password``. :rtype: bool """ return self._tag == 'remove_password' def is_set_expiry(self): """ Check if the union tag is ``set_expiry``. :rtype: bool """ return self._tag == 'set_expiry' def is_set_password(self): """ Check if the union tag is ``set_password``. :rtype: bool """ return self._tag == 'set_password' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'LinkAction(%r, %r)' % (self._tag, self._value) LinkAction_validator = bv.Union(LinkAction) class LinkAudience(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar public: Link is accessible by anyone. :ivar team: Link is accessible only by team members. :ivar members: Link is accessible only by members of the content. """ _catch_all = 'other' # Attribute is overwritten below the class definition public = None # Attribute is overwritten below the class definition team = None # Attribute is overwritten below the class definition members = None # Attribute is overwritten below the class definition other = None def is_public(self): """ Check if the union tag is ``public``. :rtype: bool """ return self._tag == 'public' def is_team(self): """ Check if the union tag is ``team``. :rtype: bool """ return self._tag == 'team' def is_members(self): """ Check if the union tag is ``members``. :rtype: bool """ return self._tag == 'members' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'LinkAudience(%r, %r)' % (self._tag, self._value) LinkAudience_validator = bv.Union(LinkAudience) class LinkExpiry(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar remove_expiry: Remove the currently set expiry for the link. :ivar datetime.datetime set_expiry: Set a new expiry or change an existing expiry. """ _catch_all = 'other' # Attribute is overwritten below the class definition remove_expiry = None # Attribute is overwritten below the class definition other = None @classmethod def set_expiry(cls, val): """ Create an instance of this class set to the ``set_expiry`` tag with value ``val``. :param datetime.datetime val: :rtype: LinkExpiry """ return cls('set_expiry', val) def is_remove_expiry(self): """ Check if the union tag is ``remove_expiry``. :rtype: bool """ return self._tag == 'remove_expiry' def is_set_expiry(self): """ Check if the union tag is ``set_expiry``. :rtype: bool """ return self._tag == 'set_expiry' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_set_expiry(self): """ Set a new expiry or change an existing expiry. Only call this if :meth:`is_set_expiry` is true. :rtype: datetime.datetime """ if not self.is_set_expiry(): raise AttributeError("tag 'set_expiry' not set") return self._value def __repr__(self): return 'LinkExpiry(%r, %r)' % (self._tag, self._value) LinkExpiry_validator = bv.Union(LinkExpiry) class LinkPassword(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar remove_password: Remove the currently set password for the link. :ivar str set_password: Set a new password or change an existing password. """ _catch_all = 'other' # Attribute is overwritten below the class definition remove_password = None # Attribute is overwritten below the class definition other = None @classmethod def set_password(cls, val): """ Create an instance of this class set to the ``set_password`` tag with value ``val``. :param str val: :rtype: LinkPassword """ return cls('set_password', val) def is_remove_password(self): """ Check if the union tag is ``remove_password``. :rtype: bool """ return self._tag == 'remove_password' def is_set_password(self): """ Check if the union tag is ``set_password``. :rtype: bool """ return self._tag == 'set_password' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_set_password(self): """ Set a new password or change an existing password. Only call this if :meth:`is_set_password` is true. :rtype: str """ if not self.is_set_password(): raise AttributeError("tag 'set_password' not set") return self._value def __repr__(self): return 'LinkPassword(%r, %r)' % (self._tag, self._value) LinkPassword_validator = bv.Union(LinkPassword) class LinkPermission(object): """ Permissions for actions that can be performed on a link. """ __slots__ = [ '_action_value', '_action_present', '_allow_value', '_allow_present', '_reason_value', '_reason_present', ] _has_required_fields = True def __init__(self, action=None, allow=None, reason=None): self._action_value = None self._action_present = False self._allow_value = None self._allow_present = False self._reason_value = None self._reason_present = False if action is not None: self.action = action if allow is not None: self.allow = allow if reason is not None: self.reason = reason @property def action(self): """ :rtype: LinkAction """ if self._action_present: return self._action_value else: raise AttributeError("missing required field 'action'") @action.setter def action(self, val): self._action_validator.validate_type_only(val) self._action_value = val self._action_present = True @action.deleter def action(self): self._action_value = None self._action_present = False @property def allow(self): """ :rtype: bool """ if self._allow_present: return self._allow_value else: raise AttributeError("missing required field 'allow'") @allow.setter def allow(self, val): val = self._allow_validator.validate(val) self._allow_value = val self._allow_present = True @allow.deleter def allow(self): self._allow_value = None self._allow_present = False @property def reason(self): """ :rtype: PermissionDeniedReason """ if self._reason_present: return self._reason_value else: return None @reason.setter def reason(self, val): if val is None: del self.reason return self._reason_validator.validate_type_only(val) self._reason_value = val self._reason_present = True @reason.deleter def reason(self): self._reason_value = None self._reason_present = False def __repr__(self): return 'LinkPermission(action={!r}, allow={!r}, reason={!r})'.format( self._action_value, self._allow_value, self._reason_value, ) LinkPermission_validator = bv.Struct(LinkPermission) class LinkPermissions(object): """ :ivar resolved_visibility: The current visibility of the link after considering the shared links policies of the the team (in case the link's owner is part of a team) and the shared folder (in case the linked file is part of a shared folder). This field is shown only if the caller has access to this info (the link's owner always has access to this data). :ivar requested_visibility: The shared link's requested visibility. This can be overridden by the team and shared folder policies. The final visibility, after considering these policies, can be found in ``resolved_visibility``. This is shown only if the caller is the link's owner. :ivar can_revoke: Whether the caller can revoke the shared link. :ivar revoke_failure_reason: The failure reason for revoking the link. This field will only be present if the ``can_revoke`` is ``False``. """ __slots__ = [ '_resolved_visibility_value', '_resolved_visibility_present', '_requested_visibility_value', '_requested_visibility_present', '_can_revoke_value', '_can_revoke_present', '_revoke_failure_reason_value', '_revoke_failure_reason_present', ] _has_required_fields = True def __init__(self, can_revoke=None, resolved_visibility=None, requested_visibility=None, revoke_failure_reason=None): self._resolved_visibility_value = None self._resolved_visibility_present = False self._requested_visibility_value = None self._requested_visibility_present = False self._can_revoke_value = None self._can_revoke_present = False self._revoke_failure_reason_value = None self._revoke_failure_reason_present = False if resolved_visibility is not None: self.resolved_visibility = resolved_visibility if requested_visibility is not None: self.requested_visibility = requested_visibility if can_revoke is not None: self.can_revoke = can_revoke if revoke_failure_reason is not None: self.revoke_failure_reason = revoke_failure_reason @property def resolved_visibility(self): """ The current visibility of the link after considering the shared links policies of the the team (in case the link's owner is part of a team) and the shared folder (in case the linked file is part of a shared folder). This field is shown only if the caller has access to this info (the link's owner always has access to this data). :rtype: ResolvedVisibility """ if self._resolved_visibility_present: return self._resolved_visibility_value else: return None @resolved_visibility.setter def resolved_visibility(self, val): if val is None: del self.resolved_visibility return self._resolved_visibility_validator.validate_type_only(val) self._resolved_visibility_value = val self._resolved_visibility_present = True @resolved_visibility.deleter def resolved_visibility(self): self._resolved_visibility_value = None self._resolved_visibility_present = False @property def requested_visibility(self): """ The shared link's requested visibility. This can be overridden by the team and shared folder policies. The final visibility, after considering these policies, can be found in ``resolved_visibility``. This is shown only if the caller is the link's owner. :rtype: RequestedVisibility """ if self._requested_visibility_present: return self._requested_visibility_value else: return None @requested_visibility.setter def requested_visibility(self, val): if val is None: del self.requested_visibility return self._requested_visibility_validator.validate_type_only(val) self._requested_visibility_value = val self._requested_visibility_present = True @requested_visibility.deleter def requested_visibility(self): self._requested_visibility_value = None self._requested_visibility_present = False @property def can_revoke(self): """ Whether the caller can revoke the shared link. :rtype: bool """ if self._can_revoke_present: return self._can_revoke_value else: raise AttributeError("missing required field 'can_revoke'") @can_revoke.setter def can_revoke(self, val): val = self._can_revoke_validator.validate(val) self._can_revoke_value = val self._can_revoke_present = True @can_revoke.deleter def can_revoke(self): self._can_revoke_value = None self._can_revoke_present = False @property def revoke_failure_reason(self): """ The failure reason for revoking the link. This field will only be present if the ``can_revoke`` is ``False``. :rtype: SharedLinkAccessFailureReason """ if self._revoke_failure_reason_present: return self._revoke_failure_reason_value else: return None @revoke_failure_reason.setter def revoke_failure_reason(self, val): if val is None: del self.revoke_failure_reason return self._revoke_failure_reason_validator.validate_type_only(val) self._revoke_failure_reason_value = val self._revoke_failure_reason_present = True @revoke_failure_reason.deleter def revoke_failure_reason(self): self._revoke_failure_reason_value = None self._revoke_failure_reason_present = False def __repr__(self): return 'LinkPermissions(can_revoke={!r}, resolved_visibility={!r}, requested_visibility={!r}, revoke_failure_reason={!r})'.format( self._can_revoke_value, self._resolved_visibility_value, self._requested_visibility_value, self._revoke_failure_reason_value, ) LinkPermissions_validator = bv.Struct(LinkPermissions) class LinkSettings(object): """ Settings that apply to a link. :ivar access_level: The access level on the link for this file. Currently, it only accepts 'viewer' and 'viewer_no_comment'. :ivar audience: The type of audience on the link for this file. :ivar expiry: An expiry timestamp to set on a link. :ivar password: The password for the link. """ __slots__ = [ '_access_level_value', '_access_level_present', '_audience_value', '_audience_present', '_expiry_value', '_expiry_present', '_password_value', '_password_present', ] _has_required_fields = False def __init__(self, access_level=None, audience=None, expiry=None, password=None): self._access_level_value = None self._access_level_present = False self._audience_value = None self._audience_present = False self._expiry_value = None self._expiry_present = False self._password_value = None self._password_present = False if access_level is not None: self.access_level = access_level if audience is not None: self.audience = audience if expiry is not None: self.expiry = expiry if password is not None: self.password = password @property def access_level(self): """ The access level on the link for this file. Currently, it only accepts 'viewer' and 'viewer_no_comment'. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: return None @access_level.setter def access_level(self, val): if val is None: del self.access_level return self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False @property def audience(self): """ The type of audience on the link for this file. :rtype: LinkAudience """ if self._audience_present: return self._audience_value else: return None @audience.setter def audience(self, val): if val is None: del self.audience return self._audience_validator.validate_type_only(val) self._audience_value = val self._audience_present = True @audience.deleter def audience(self): self._audience_value = None self._audience_present = False @property def expiry(self): """ An expiry timestamp to set on a link. :rtype: LinkExpiry """ if self._expiry_present: return self._expiry_value else: return None @expiry.setter def expiry(self, val): if val is None: del self.expiry return self._expiry_validator.validate_type_only(val) self._expiry_value = val self._expiry_present = True @expiry.deleter def expiry(self): self._expiry_value = None self._expiry_present = False @property def password(self): """ The password for the link. :rtype: LinkPassword """ if self._password_present: return self._password_value else: return None @password.setter def password(self, val): if val is None: del self.password return self._password_validator.validate_type_only(val) self._password_value = val self._password_present = True @password.deleter def password(self): self._password_value = None self._password_present = False def __repr__(self): return 'LinkSettings(access_level={!r}, audience={!r}, expiry={!r}, password={!r})'.format( self._access_level_value, self._audience_value, self._expiry_value, self._password_value, ) LinkSettings_validator = bv.Struct(LinkSettings) class ListFileMembersArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members`. :ivar file: The file for which you want to see members. :ivar actions: The actions for which to return permissions on a member. :ivar include_inherited: Whether to include members who only have access from a parent shared folder. :ivar limit: Number of members to return max per query. Defaults to 100 if no limit is specified. """ __slots__ = [ '_file_value', '_file_present', '_actions_value', '_actions_present', '_include_inherited_value', '_include_inherited_present', '_limit_value', '_limit_present', ] _has_required_fields = True def __init__(self, file=None, actions=None, include_inherited=None, limit=None): self._file_value = None self._file_present = False self._actions_value = None self._actions_present = False self._include_inherited_value = None self._include_inherited_present = False self._limit_value = None self._limit_present = False if file is not None: self.file = file if actions is not None: self.actions = actions if include_inherited is not None: self.include_inherited = include_inherited if limit is not None: self.limit = limit @property def file(self): """ The file for which you want to see members. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def actions(self): """ The actions for which to return permissions on a member. :rtype: list of [MemberAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False @property def include_inherited(self): """ Whether to include members who only have access from a parent shared folder. :rtype: bool """ if self._include_inherited_present: return self._include_inherited_value else: return True @include_inherited.setter def include_inherited(self, val): val = self._include_inherited_validator.validate(val) self._include_inherited_value = val self._include_inherited_present = True @include_inherited.deleter def include_inherited(self): self._include_inherited_value = None self._include_inherited_present = False @property def limit(self): """ Number of members to return max per query. Defaults to 100 if no limit is specified. :rtype: long """ if self._limit_present: return self._limit_value else: return 100 @limit.setter def limit(self, val): val = self._limit_validator.validate(val) self._limit_value = val self._limit_present = True @limit.deleter def limit(self): self._limit_value = None self._limit_present = False def __repr__(self): return 'ListFileMembersArg(file={!r}, actions={!r}, include_inherited={!r}, limit={!r})'.format( self._file_value, self._actions_value, self._include_inherited_value, self._limit_value, ) ListFileMembersArg_validator = bv.Struct(ListFileMembersArg) class ListFileMembersBatchArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`. :ivar files: Files for which to return members. :ivar limit: Number of members to return max per query. Defaults to 10 if no limit is specified. """ __slots__ = [ '_files_value', '_files_present', '_limit_value', '_limit_present', ] _has_required_fields = True def __init__(self, files=None, limit=None): self._files_value = None self._files_present = False self._limit_value = None self._limit_present = False if files is not None: self.files = files if limit is not None: self.limit = limit @property def files(self): """ Files for which to return members. :rtype: list of [str] """ if self._files_present: return self._files_value else: raise AttributeError("missing required field 'files'") @files.setter def files(self, val): val = self._files_validator.validate(val) self._files_value = val self._files_present = True @files.deleter def files(self): self._files_value = None self._files_present = False @property def limit(self): """ Number of members to return max per query. Defaults to 10 if no limit is specified. :rtype: long """ if self._limit_present: return self._limit_value else: return 10 @limit.setter def limit(self, val): val = self._limit_validator.validate(val) self._limit_value = val self._limit_present = True @limit.deleter def limit(self): self._limit_value = None self._limit_present = False def __repr__(self): return 'ListFileMembersBatchArg(files={!r}, limit={!r})'.format( self._files_value, self._limit_value, ) ListFileMembersBatchArg_validator = bv.Struct(ListFileMembersBatchArg) class ListFileMembersBatchResult(object): """ Per-file result for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`. :ivar file: This is the input file identifier, whether an ID or a path. :ivar result: The result for this particular file. """ __slots__ = [ '_file_value', '_file_present', '_result_value', '_result_present', ] _has_required_fields = True def __init__(self, file=None, result=None): self._file_value = None self._file_present = False self._result_value = None self._result_present = False if file is not None: self.file = file if result is not None: self.result = result @property def file(self): """ This is the input file identifier, whether an ID or a path. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def result(self): """ The result for this particular file. :rtype: ListFileMembersIndividualResult """ if self._result_present: return self._result_value else: raise AttributeError("missing required field 'result'") @result.setter def result(self, val): self._result_validator.validate_type_only(val) self._result_value = val self._result_present = True @result.deleter def result(self): self._result_value = None self._result_present = False def __repr__(self): return 'ListFileMembersBatchResult(file={!r}, result={!r})'.format( self._file_value, self._result_value, ) ListFileMembersBatchResult_validator = bv.Struct(ListFileMembersBatchResult) class ListFileMembersContinueArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`. :ivar cursor: The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members`, :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`, or :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`. """ __slots__ = [ '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, cursor=None): self._cursor_value = None self._cursor_present = False if cursor is not None: self.cursor = cursor @property def cursor(self): """ The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members`, :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`, or :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`. :rtype: str """ if self._cursor_present: return self._cursor_value else: raise AttributeError("missing required field 'cursor'") @cursor.setter def cursor(self, val): val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFileMembersContinueArg(cursor={!r})'.format( self._cursor_value, ) ListFileMembersContinueArg_validator = bv.Struct(ListFileMembersContinueArg) class ListFileMembersContinueError(bb.Union): """ Error for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_cursor: ``ListFileMembersContinueArg.cursor`` is invalid. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_cursor = None # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: ListFileMembersContinueError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: ListFileMembersContinueError """ return cls('access_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_invalid_cursor(self): """ Check if the union tag is ``invalid_cursor``. :rtype: bool """ return self._tag == 'invalid_cursor' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'ListFileMembersContinueError(%r, %r)' % (self._tag, self._value) ListFileMembersContinueError_validator = bv.Union(ListFileMembersContinueError) class ListFileMembersCountResult(object): """ :ivar members: A list of members on this file. :ivar member_count: The number of members on this file. This does not include inherited members. """ __slots__ = [ '_members_value', '_members_present', '_member_count_value', '_member_count_present', ] _has_required_fields = True def __init__(self, members=None, member_count=None): self._members_value = None self._members_present = False self._member_count_value = None self._member_count_present = False if members is not None: self.members = members if member_count is not None: self.member_count = member_count @property def members(self): """ A list of members on this file. :rtype: SharedFileMembers """ if self._members_present: return self._members_value else: raise AttributeError("missing required field 'members'") @members.setter def members(self, val): self._members_validator.validate_type_only(val) self._members_value = val self._members_present = True @members.deleter def members(self): self._members_value = None self._members_present = False @property def member_count(self): """ The number of members on this file. This does not include inherited members. :rtype: long """ if self._member_count_present: return self._member_count_value else: raise AttributeError("missing required field 'member_count'") @member_count.setter def member_count(self, val): val = self._member_count_validator.validate(val) self._member_count_value = val self._member_count_present = True @member_count.deleter def member_count(self): self._member_count_value = None self._member_count_present = False def __repr__(self): return 'ListFileMembersCountResult(members={!r}, member_count={!r})'.format( self._members_value, self._member_count_value, ) ListFileMembersCountResult_validator = bv.Struct(ListFileMembersCountResult) class ListFileMembersError(bb.Union): """ Error for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: ListFileMembersError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: ListFileMembersError """ return cls('access_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'ListFileMembersError(%r, %r)' % (self._tag, self._value) ListFileMembersError_validator = bv.Union(ListFileMembersError) class ListFileMembersIndividualResult(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar ListFileMembersCountResult result: The results of the query for this file if it was successful. :ivar SharingFileAccessError access_error: The result of the query for this file if it was an error. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def result(cls, val): """ Create an instance of this class set to the ``result`` tag with value ``val``. :param ListFileMembersCountResult val: :rtype: ListFileMembersIndividualResult """ return cls('result', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: ListFileMembersIndividualResult """ return cls('access_error', val) def is_result(self): """ Check if the union tag is ``result``. :rtype: bool """ return self._tag == 'result' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_result(self): """ The results of the query for this file if it was successful. Only call this if :meth:`is_result` is true. :rtype: ListFileMembersCountResult """ if not self.is_result(): raise AttributeError("tag 'result' not set") return self._value def get_access_error(self): """ The result of the query for this file if it was an error. Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'ListFileMembersIndividualResult(%r, %r)' % (self._tag, self._value) ListFileMembersIndividualResult_validator = bv.Union(ListFileMembersIndividualResult) class ListFilesArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_received_files`. :ivar limit: Number of files to return max per query. Defaults to 100 if no limit is specified. :ivar actions: A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. """ __slots__ = [ '_limit_value', '_limit_present', '_actions_value', '_actions_present', ] _has_required_fields = False def __init__(self, limit=None, actions=None): self._limit_value = None self._limit_present = False self._actions_value = None self._actions_present = False if limit is not None: self.limit = limit if actions is not None: self.actions = actions @property def limit(self): """ Number of files to return max per query. Defaults to 100 if no limit is specified. :rtype: long """ if self._limit_present: return self._limit_value else: return 100 @limit.setter def limit(self, val): val = self._limit_validator.validate(val) self._limit_value = val self._limit_present = True @limit.deleter def limit(self): self._limit_value = None self._limit_present = False @property def actions(self): """ A list of `FileAction`s corresponding to `FilePermission`s that should appear in the response's ``SharedFileMetadata.permissions`` field describing the actions the authenticated user can perform on the file. :rtype: list of [FileAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'ListFilesArg(limit={!r}, actions={!r})'.format( self._limit_value, self._actions_value, ) ListFilesArg_validator = bv.Struct(ListFilesArg) class ListFilesContinueArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_received_files_continue`. :ivar cursor: Cursor in ``ListFilesResult.cursor``. """ __slots__ = [ '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, cursor=None): self._cursor_value = None self._cursor_present = False if cursor is not None: self.cursor = cursor @property def cursor(self): """ Cursor in ``ListFilesResult.cursor``. :rtype: str """ if self._cursor_present: return self._cursor_value else: raise AttributeError("missing required field 'cursor'") @cursor.setter def cursor(self, val): val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFilesContinueArg(cursor={!r})'.format( self._cursor_value, ) ListFilesContinueArg_validator = bv.Struct(ListFilesContinueArg) class ListFilesContinueError(bb.Union): """ Error results for :meth:`dropbox.dropbox.Dropbox.sharing_list_received_files_continue`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar SharingUserError user_error: User account had a problem. :ivar invalid_cursor: ``ListFilesContinueArg.cursor`` is invalid. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_cursor = None # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: ListFilesContinueError """ return cls('user_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_invalid_cursor(self): """ Check if the union tag is ``invalid_cursor``. :rtype: bool """ return self._tag == 'invalid_cursor' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ User account had a problem. Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def __repr__(self): return 'ListFilesContinueError(%r, %r)' % (self._tag, self._value) ListFilesContinueError_validator = bv.Union(ListFilesContinueError) class ListFilesResult(object): """ Success results for :meth:`dropbox.dropbox.Dropbox.sharing_list_received_files`. :ivar entries: Information about the files shared with current user. :ivar cursor: Cursor used to obtain additional shared files. """ __slots__ = [ '_entries_value', '_entries_present', '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, entries=None, cursor=None): self._entries_value = None self._entries_present = False self._cursor_value = None self._cursor_present = False if entries is not None: self.entries = entries if cursor is not None: self.cursor = cursor @property def entries(self): """ Information about the files shared with current user. :rtype: list of [SharedFileMetadata] """ if self._entries_present: return self._entries_value else: raise AttributeError("missing required field 'entries'") @entries.setter def entries(self, val): val = self._entries_validator.validate(val) self._entries_value = val self._entries_present = True @entries.deleter def entries(self): self._entries_value = None self._entries_present = False @property def cursor(self): """ Cursor used to obtain additional shared files. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFilesResult(entries={!r}, cursor={!r})'.format( self._entries_value, self._cursor_value, ) ListFilesResult_validator = bv.Struct(ListFilesResult) class ListFolderMembersCursorArg(object): """ :ivar actions: This is a list indicating whether each returned member will include a boolean value ``MemberPermission.allow`` that describes whether the current user can perform the MemberAction on the member. :ivar limit: The maximum number of results that include members, groups and invitees to return per request. """ __slots__ = [ '_actions_value', '_actions_present', '_limit_value', '_limit_present', ] _has_required_fields = False def __init__(self, actions=None, limit=None): self._actions_value = None self._actions_present = False self._limit_value = None self._limit_present = False if actions is not None: self.actions = actions if limit is not None: self.limit = limit @property def actions(self): """ This is a list indicating whether each returned member will include a boolean value ``MemberPermission.allow`` that describes whether the current user can perform the MemberAction on the member. :rtype: list of [MemberAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False @property def limit(self): """ The maximum number of results that include members, groups and invitees to return per request. :rtype: long """ if self._limit_present: return self._limit_value else: return 1000 @limit.setter def limit(self, val): val = self._limit_validator.validate(val) self._limit_value = val self._limit_present = True @limit.deleter def limit(self): self._limit_value = None self._limit_present = False def __repr__(self): return 'ListFolderMembersCursorArg(actions={!r}, limit={!r})'.format( self._actions_value, self._limit_value, ) ListFolderMembersCursorArg_validator = bv.Struct(ListFolderMembersCursorArg) class ListFolderMembersArgs(ListFolderMembersCursorArg): """ :ivar shared_folder_id: The ID for the shared folder. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, actions=None, limit=None): super(ListFolderMembersArgs, self).__init__(actions, limit) self._shared_folder_id_value = None self._shared_folder_id_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False def __repr__(self): return 'ListFolderMembersArgs(shared_folder_id={!r}, actions={!r}, limit={!r})'.format( self._shared_folder_id_value, self._actions_value, self._limit_value, ) ListFolderMembersArgs_validator = bv.Struct(ListFolderMembersArgs) class ListFolderMembersContinueArg(object): """ :ivar cursor: The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members` or :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members_continue`. """ __slots__ = [ '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, cursor=None): self._cursor_value = None self._cursor_present = False if cursor is not None: self.cursor = cursor @property def cursor(self): """ The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members` or :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members_continue`. :rtype: str """ if self._cursor_present: return self._cursor_value else: raise AttributeError("missing required field 'cursor'") @cursor.setter def cursor(self, val): val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFolderMembersContinueArg(cursor={!r})'.format( self._cursor_value, ) ListFolderMembersContinueArg_validator = bv.Struct(ListFolderMembersContinueArg) class ListFolderMembersContinueError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_cursor: ``ListFolderMembersContinueArg.cursor`` is invalid. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_cursor = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: ListFolderMembersContinueError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_invalid_cursor(self): """ Check if the union tag is ``invalid_cursor``. :rtype: bool """ return self._tag == 'invalid_cursor' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'ListFolderMembersContinueError(%r, %r)' % (self._tag, self._value) ListFolderMembersContinueError_validator = bv.Union(ListFolderMembersContinueError) class ListFoldersArgs(object): """ :ivar limit: The maximum number of results to return per request. :ivar actions: A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. """ __slots__ = [ '_limit_value', '_limit_present', '_actions_value', '_actions_present', ] _has_required_fields = False def __init__(self, limit=None, actions=None): self._limit_value = None self._limit_present = False self._actions_value = None self._actions_present = False if limit is not None: self.limit = limit if actions is not None: self.actions = actions @property def limit(self): """ The maximum number of results to return per request. :rtype: long """ if self._limit_present: return self._limit_value else: return 1000 @limit.setter def limit(self, val): val = self._limit_validator.validate(val) self._limit_value = val self._limit_present = True @limit.deleter def limit(self): self._limit_value = None self._limit_present = False @property def actions(self): """ A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. :rtype: list of [FolderAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'ListFoldersArgs(limit={!r}, actions={!r})'.format( self._limit_value, self._actions_value, ) ListFoldersArgs_validator = bv.Struct(ListFoldersArgs) class ListFoldersContinueArg(object): """ :ivar cursor: The cursor returned by the previous API call specified in the endpoint description. """ __slots__ = [ '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, cursor=None): self._cursor_value = None self._cursor_present = False if cursor is not None: self.cursor = cursor @property def cursor(self): """ The cursor returned by the previous API call specified in the endpoint description. :rtype: str """ if self._cursor_present: return self._cursor_value else: raise AttributeError("missing required field 'cursor'") @cursor.setter def cursor(self, val): val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFoldersContinueArg(cursor={!r})'.format( self._cursor_value, ) ListFoldersContinueArg_validator = bv.Struct(ListFoldersContinueArg) class ListFoldersContinueError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_cursor: ``ListFoldersContinueArg.cursor`` is invalid. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_cursor = None # Attribute is overwritten below the class definition other = None def is_invalid_cursor(self): """ Check if the union tag is ``invalid_cursor``. :rtype: bool """ return self._tag == 'invalid_cursor' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'ListFoldersContinueError(%r, %r)' % (self._tag, self._value) ListFoldersContinueError_validator = bv.Union(ListFoldersContinueError) class ListFoldersResult(object): """ Result for :meth:`dropbox.dropbox.Dropbox.sharing_list_folders` or :meth:`dropbox.dropbox.Dropbox.sharing_list_mountable_folders`, depending on which endpoint was requested. Unmounted shared folders can be identified by the absence of ``SharedFolderMetadata.path_lower``. :ivar entries: List of all shared folders the authenticated user has access to. :ivar cursor: Present if there are additional shared folders that have not been returned yet. Pass the cursor into the corresponding continue endpoint (either :meth:`dropbox.dropbox.Dropbox.sharing_list_folders_continue` or :meth:`dropbox.dropbox.Dropbox.sharing_list_mountable_folders_continue`) to list additional folders. """ __slots__ = [ '_entries_value', '_entries_present', '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, entries=None, cursor=None): self._entries_value = None self._entries_present = False self._cursor_value = None self._cursor_present = False if entries is not None: self.entries = entries if cursor is not None: self.cursor = cursor @property def entries(self): """ List of all shared folders the authenticated user has access to. :rtype: list of [SharedFolderMetadata] """ if self._entries_present: return self._entries_value else: raise AttributeError("missing required field 'entries'") @entries.setter def entries(self, val): val = self._entries_validator.validate(val) self._entries_value = val self._entries_present = True @entries.deleter def entries(self): self._entries_value = None self._entries_present = False @property def cursor(self): """ Present if there are additional shared folders that have not been returned yet. Pass the cursor into the corresponding continue endpoint (either :meth:`dropbox.dropbox.Dropbox.sharing_list_folders_continue` or :meth:`dropbox.dropbox.Dropbox.sharing_list_mountable_folders_continue`) to list additional folders. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListFoldersResult(entries={!r}, cursor={!r})'.format( self._entries_value, self._cursor_value, ) ListFoldersResult_validator = bv.Struct(ListFoldersResult) class ListSharedLinksArg(object): """ :ivar path: See :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` description. :ivar cursor: The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links`. :ivar direct_only: See :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` description. """ __slots__ = [ '_path_value', '_path_present', '_cursor_value', '_cursor_present', '_direct_only_value', '_direct_only_present', ] _has_required_fields = False def __init__(self, path=None, cursor=None, direct_only=None): self._path_value = None self._path_present = False self._cursor_value = None self._cursor_present = False self._direct_only_value = None self._direct_only_present = False if path is not None: self.path = path if cursor is not None: self.cursor = cursor if direct_only is not None: self.direct_only = direct_only @property def path(self): """ See :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` description. :rtype: str """ if self._path_present: return self._path_value else: return None @path.setter def path(self, val): if val is None: del self.path return val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False @property def cursor(self): """ The cursor returned by your last call to :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links`. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False @property def direct_only(self): """ See :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` description. :rtype: bool """ if self._direct_only_present: return self._direct_only_value else: return None @direct_only.setter def direct_only(self, val): if val is None: del self.direct_only return val = self._direct_only_validator.validate(val) self._direct_only_value = val self._direct_only_present = True @direct_only.deleter def direct_only(self): self._direct_only_value = None self._direct_only_present = False def __repr__(self): return 'ListSharedLinksArg(path={!r}, cursor={!r}, direct_only={!r})'.format( self._path_value, self._cursor_value, self._direct_only_value, ) ListSharedLinksArg_validator = bv.Struct(ListSharedLinksArg) class ListSharedLinksError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar reset: Indicates that the cursor has been invalidated. Call :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to obtain a new cursor. """ _catch_all = 'other' # Attribute is overwritten below the class definition reset = None # Attribute is overwritten below the class definition other = None @classmethod def path(cls, val): """ Create an instance of this class set to the ``path`` tag with value ``val``. :param files.LookupError_validator val: :rtype: ListSharedLinksError """ return cls('path', val) def is_path(self): """ Check if the union tag is ``path``. :rtype: bool """ return self._tag == 'path' def is_reset(self): """ Check if the union tag is ``reset``. :rtype: bool """ return self._tag == 'reset' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_path(self): """ Only call this if :meth:`is_path` is true. :rtype: files.LookupError_validator """ if not self.is_path(): raise AttributeError("tag 'path' not set") return self._value def __repr__(self): return 'ListSharedLinksError(%r, %r)' % (self._tag, self._value) ListSharedLinksError_validator = bv.Union(ListSharedLinksError) class ListSharedLinksResult(object): """ :ivar links: Shared links applicable to the path argument. :ivar has_more: Is true if there are additional shared links that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to retrieve them. :ivar cursor: Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to obtain the additional links. Cursor is returned only if no path is given. """ __slots__ = [ '_links_value', '_links_present', '_has_more_value', '_has_more_present', '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, links=None, has_more=None, cursor=None): self._links_value = None self._links_present = False self._has_more_value = None self._has_more_present = False self._cursor_value = None self._cursor_present = False if links is not None: self.links = links if has_more is not None: self.has_more = has_more if cursor is not None: self.cursor = cursor @property def links(self): """ Shared links applicable to the path argument. :rtype: list of [SharedLinkMetadata] """ if self._links_present: return self._links_value else: raise AttributeError("missing required field 'links'") @links.setter def links(self, val): val = self._links_validator.validate(val) self._links_value = val self._links_present = True @links.deleter def links(self): self._links_value = None self._links_present = False @property def has_more(self): """ Is true if there are additional shared links that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to retrieve them. :rtype: bool """ if self._has_more_present: return self._has_more_value else: raise AttributeError("missing required field 'has_more'") @has_more.setter def has_more(self, val): val = self._has_more_validator.validate(val) self._has_more_value = val self._has_more_present = True @has_more.deleter def has_more(self): self._has_more_value = None self._has_more_present = False @property def cursor(self): """ Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to obtain the additional links. Cursor is returned only if no path is given. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'ListSharedLinksResult(links={!r}, has_more={!r}, cursor={!r})'.format( self._links_value, self._has_more_value, self._cursor_value, ) ListSharedLinksResult_validator = bv.Struct(ListSharedLinksResult) class MemberAccessLevelResult(object): """ Contains information about a member's access level to content after an operation. :ivar access_level: The member still has this level of access to the content through a parent folder. :ivar warning: A localized string with additional information about why the user has this access level to the content. :ivar access_details: The parent folders that a member has access to. The field is present if the user has access to the first parent folder where the member gains access. """ __slots__ = [ '_access_level_value', '_access_level_present', '_warning_value', '_warning_present', '_access_details_value', '_access_details_present', ] _has_required_fields = False def __init__(self, access_level=None, warning=None, access_details=None): self._access_level_value = None self._access_level_present = False self._warning_value = None self._warning_present = False self._access_details_value = None self._access_details_present = False if access_level is not None: self.access_level = access_level if warning is not None: self.warning = warning if access_details is not None: self.access_details = access_details @property def access_level(self): """ The member still has this level of access to the content through a parent folder. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: return None @access_level.setter def access_level(self, val): if val is None: del self.access_level return self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False @property def warning(self): """ A localized string with additional information about why the user has this access level to the content. :rtype: str """ if self._warning_present: return self._warning_value else: return None @warning.setter def warning(self, val): if val is None: del self.warning return val = self._warning_validator.validate(val) self._warning_value = val self._warning_present = True @warning.deleter def warning(self): self._warning_value = None self._warning_present = False @property def access_details(self): """ The parent folders that a member has access to. The field is present if the user has access to the first parent folder where the member gains access. :rtype: list of [ParentFolderAccessInfo] """ if self._access_details_present: return self._access_details_value else: return None @access_details.setter def access_details(self, val): if val is None: del self.access_details return val = self._access_details_validator.validate(val) self._access_details_value = val self._access_details_present = True @access_details.deleter def access_details(self): self._access_details_value = None self._access_details_present = False def __repr__(self): return 'MemberAccessLevelResult(access_level={!r}, warning={!r}, access_details={!r})'.format( self._access_level_value, self._warning_value, self._access_details_value, ) MemberAccessLevelResult_validator = bv.Struct(MemberAccessLevelResult) class MemberAction(bb.Union): """ Actions that may be taken on members of a shared folder. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar leave_a_copy: Allow the member to keep a copy of the folder when removing. :ivar make_editor: Make the member an editor of the folder. :ivar make_owner: Make the member an owner of the folder. :ivar make_viewer: Make the member a viewer of the folder. :ivar make_viewer_no_comment: Make the member a viewer of the folder without commenting permissions. :ivar remove: Remove the member from the folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition leave_a_copy = None # Attribute is overwritten below the class definition make_editor = None # Attribute is overwritten below the class definition make_owner = None # Attribute is overwritten below the class definition make_viewer = None # Attribute is overwritten below the class definition make_viewer_no_comment = None # Attribute is overwritten below the class definition remove = None # Attribute is overwritten below the class definition other = None def is_leave_a_copy(self): """ Check if the union tag is ``leave_a_copy``. :rtype: bool """ return self._tag == 'leave_a_copy' def is_make_editor(self): """ Check if the union tag is ``make_editor``. :rtype: bool """ return self._tag == 'make_editor' def is_make_owner(self): """ Check if the union tag is ``make_owner``. :rtype: bool """ return self._tag == 'make_owner' def is_make_viewer(self): """ Check if the union tag is ``make_viewer``. :rtype: bool """ return self._tag == 'make_viewer' def is_make_viewer_no_comment(self): """ Check if the union tag is ``make_viewer_no_comment``. :rtype: bool """ return self._tag == 'make_viewer_no_comment' def is_remove(self): """ Check if the union tag is ``remove``. :rtype: bool """ return self._tag == 'remove' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'MemberAction(%r, %r)' % (self._tag, self._value) MemberAction_validator = bv.Union(MemberAction) class MemberPermission(object): """ Whether the user is allowed to take the action on the associated member. :ivar action: The action that the user may wish to take on the member. :ivar allow: True if the user is allowed to take the action. :ivar reason: The reason why the user is denied the permission. Not present if the action is allowed. """ __slots__ = [ '_action_value', '_action_present', '_allow_value', '_allow_present', '_reason_value', '_reason_present', ] _has_required_fields = True def __init__(self, action=None, allow=None, reason=None): self._action_value = None self._action_present = False self._allow_value = None self._allow_present = False self._reason_value = None self._reason_present = False if action is not None: self.action = action if allow is not None: self.allow = allow if reason is not None: self.reason = reason @property def action(self): """ The action that the user may wish to take on the member. :rtype: MemberAction """ if self._action_present: return self._action_value else: raise AttributeError("missing required field 'action'") @action.setter def action(self, val): self._action_validator.validate_type_only(val) self._action_value = val self._action_present = True @action.deleter def action(self): self._action_value = None self._action_present = False @property def allow(self): """ True if the user is allowed to take the action. :rtype: bool """ if self._allow_present: return self._allow_value else: raise AttributeError("missing required field 'allow'") @allow.setter def allow(self, val): val = self._allow_validator.validate(val) self._allow_value = val self._allow_present = True @allow.deleter def allow(self): self._allow_value = None self._allow_present = False @property def reason(self): """ The reason why the user is denied the permission. Not present if the action is allowed. :rtype: PermissionDeniedReason """ if self._reason_present: return self._reason_value else: return None @reason.setter def reason(self, val): if val is None: del self.reason return self._reason_validator.validate_type_only(val) self._reason_value = val self._reason_present = True @reason.deleter def reason(self): self._reason_value = None self._reason_present = False def __repr__(self): return 'MemberPermission(action={!r}, allow={!r}, reason={!r})'.format( self._action_value, self._allow_value, self._reason_value, ) MemberPermission_validator = bv.Struct(MemberPermission) class MemberPolicy(bb.Union): """ Policy governing who can be a member of a shared folder. Only applicable to folders owned by a user on a team. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar team: Only a teammate can become a member. :ivar anyone: Anyone can become a member. """ _catch_all = 'other' # Attribute is overwritten below the class definition team = None # Attribute is overwritten below the class definition anyone = None # Attribute is overwritten below the class definition other = None def is_team(self): """ Check if the union tag is ``team``. :rtype: bool """ return self._tag == 'team' def is_anyone(self): """ Check if the union tag is ``anyone``. :rtype: bool """ return self._tag == 'anyone' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'MemberPolicy(%r, %r)' % (self._tag, self._value) MemberPolicy_validator = bv.Union(MemberPolicy) class MemberSelector(bb.Union): """ Includes different ways to identify a member of a shared folder. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar str dropbox_id: Dropbox account, team member, or group ID of member. :ivar str email: E-mail address of member. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def dropbox_id(cls, val): """ Create an instance of this class set to the ``dropbox_id`` tag with value ``val``. :param str val: :rtype: MemberSelector """ return cls('dropbox_id', val) @classmethod def email(cls, val): """ Create an instance of this class set to the ``email`` tag with value ``val``. :param str val: :rtype: MemberSelector """ return cls('email', val) def is_dropbox_id(self): """ Check if the union tag is ``dropbox_id``. :rtype: bool """ return self._tag == 'dropbox_id' def is_email(self): """ Check if the union tag is ``email``. :rtype: bool """ return self._tag == 'email' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_dropbox_id(self): """ Dropbox account, team member, or group ID of member. Only call this if :meth:`is_dropbox_id` is true. :rtype: str """ if not self.is_dropbox_id(): raise AttributeError("tag 'dropbox_id' not set") return self._value def get_email(self): """ E-mail address of member. Only call this if :meth:`is_email` is true. :rtype: str """ if not self.is_email(): raise AttributeError("tag 'email' not set") return self._value def __repr__(self): return 'MemberSelector(%r, %r)' % (self._tag, self._value) MemberSelector_validator = bv.Union(MemberSelector) class ModifySharedLinkSettingsArgs(object): """ :ivar url: URL of the shared link to change its settings. :ivar settings: Set of settings for the shared link. :ivar remove_expiration: If set to true, removes the expiration of the shared link. """ __slots__ = [ '_url_value', '_url_present', '_settings_value', '_settings_present', '_remove_expiration_value', '_remove_expiration_present', ] _has_required_fields = True def __init__(self, url=None, settings=None, remove_expiration=None): self._url_value = None self._url_present = False self._settings_value = None self._settings_present = False self._remove_expiration_value = None self._remove_expiration_present = False if url is not None: self.url = url if settings is not None: self.settings = settings if remove_expiration is not None: self.remove_expiration = remove_expiration @property def url(self): """ URL of the shared link to change its settings. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False @property def settings(self): """ Set of settings for the shared link. :rtype: SharedLinkSettings """ if self._settings_present: return self._settings_value else: raise AttributeError("missing required field 'settings'") @settings.setter def settings(self, val): self._settings_validator.validate_type_only(val) self._settings_value = val self._settings_present = True @settings.deleter def settings(self): self._settings_value = None self._settings_present = False @property def remove_expiration(self): """ If set to true, removes the expiration of the shared link. :rtype: bool """ if self._remove_expiration_present: return self._remove_expiration_value else: return False @remove_expiration.setter def remove_expiration(self, val): val = self._remove_expiration_validator.validate(val) self._remove_expiration_value = val self._remove_expiration_present = True @remove_expiration.deleter def remove_expiration(self): self._remove_expiration_value = None self._remove_expiration_present = False def __repr__(self): return 'ModifySharedLinkSettingsArgs(url={!r}, settings={!r}, remove_expiration={!r})'.format( self._url_value, self._settings_value, self._remove_expiration_value, ) ModifySharedLinkSettingsArgs_validator = bv.Struct(ModifySharedLinkSettingsArgs) class ModifySharedLinkSettingsError(SharedLinkError): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar SharedLinkSettingsError settings_error: There is an error with the given settings. :ivar email_not_verified: The caller's email should be verified. """ # Attribute is overwritten below the class definition email_not_verified = None @classmethod def settings_error(cls, val): """ Create an instance of this class set to the ``settings_error`` tag with value ``val``. :param SharedLinkSettingsError val: :rtype: ModifySharedLinkSettingsError """ return cls('settings_error', val) def is_settings_error(self): """ Check if the union tag is ``settings_error``. :rtype: bool """ return self._tag == 'settings_error' def is_email_not_verified(self): """ Check if the union tag is ``email_not_verified``. :rtype: bool """ return self._tag == 'email_not_verified' def get_settings_error(self): """ There is an error with the given settings. Only call this if :meth:`is_settings_error` is true. :rtype: SharedLinkSettingsError """ if not self.is_settings_error(): raise AttributeError("tag 'settings_error' not set") return self._value def __repr__(self): return 'ModifySharedLinkSettingsError(%r, %r)' % (self._tag, self._value) ModifySharedLinkSettingsError_validator = bv.Union(ModifySharedLinkSettingsError) class MountFolderArg(object): """ :ivar shared_folder_id: The ID of the shared folder to mount. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None): self._shared_folder_id_value = None self._shared_folder_id_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id @property def shared_folder_id(self): """ The ID of the shared folder to mount. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False def __repr__(self): return 'MountFolderArg(shared_folder_id={!r})'.format( self._shared_folder_id_value, ) MountFolderArg_validator = bv.Struct(MountFolderArg) class MountFolderError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar inside_shared_folder: Mounting would cause a shared folder to be inside another, which is disallowed. :ivar InsufficientQuotaAmounts insufficient_quota: The current user does not have enough space to mount the shared folder. :ivar already_mounted: The shared folder is already mounted. :ivar no_permission: The current user does not have permission to perform this action. :ivar not_mountable: The shared folder is not mountable. One example where this can occur is when the shared folder belongs within a team folder in the user's Dropbox. """ _catch_all = 'other' # Attribute is overwritten below the class definition inside_shared_folder = None # Attribute is overwritten below the class definition already_mounted = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition not_mountable = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: MountFolderError """ return cls('access_error', val) @classmethod def insufficient_quota(cls, val): """ Create an instance of this class set to the ``insufficient_quota`` tag with value ``val``. :param InsufficientQuotaAmounts val: :rtype: MountFolderError """ return cls('insufficient_quota', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_inside_shared_folder(self): """ Check if the union tag is ``inside_shared_folder``. :rtype: bool """ return self._tag == 'inside_shared_folder' def is_insufficient_quota(self): """ Check if the union tag is ``insufficient_quota``. :rtype: bool """ return self._tag == 'insufficient_quota' def is_already_mounted(self): """ Check if the union tag is ``already_mounted``. :rtype: bool """ return self._tag == 'already_mounted' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_not_mountable(self): """ Check if the union tag is ``not_mountable``. :rtype: bool """ return self._tag == 'not_mountable' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_insufficient_quota(self): """ The current user does not have enough space to mount the shared folder. Only call this if :meth:`is_insufficient_quota` is true. :rtype: InsufficientQuotaAmounts """ if not self.is_insufficient_quota(): raise AttributeError("tag 'insufficient_quota' not set") return self._value def __repr__(self): return 'MountFolderError(%r, %r)' % (self._tag, self._value) MountFolderError_validator = bv.Union(MountFolderError) class ParentFolderAccessInfo(object): """ Contains information about a parent folder that a member has access to. :ivar folder_name: Display name for the folder. :ivar shared_folder_id: The identifier of the parent shared folder. :ivar permissions: The user's permissions for the parent shared folder. :ivar path: The full path to the parent shared folder relative to the acting user's root. """ __slots__ = [ '_folder_name_value', '_folder_name_present', '_shared_folder_id_value', '_shared_folder_id_present', '_permissions_value', '_permissions_present', '_path_value', '_path_present', ] _has_required_fields = True def __init__(self, folder_name=None, shared_folder_id=None, permissions=None, path=None): self._folder_name_value = None self._folder_name_present = False self._shared_folder_id_value = None self._shared_folder_id_present = False self._permissions_value = None self._permissions_present = False self._path_value = None self._path_present = False if folder_name is not None: self.folder_name = folder_name if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if permissions is not None: self.permissions = permissions if path is not None: self.path = path @property def folder_name(self): """ Display name for the folder. :rtype: str """ if self._folder_name_present: return self._folder_name_value else: raise AttributeError("missing required field 'folder_name'") @folder_name.setter def folder_name(self, val): val = self._folder_name_validator.validate(val) self._folder_name_value = val self._folder_name_present = True @folder_name.deleter def folder_name(self): self._folder_name_value = None self._folder_name_present = False @property def shared_folder_id(self): """ The identifier of the parent shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def permissions(self): """ The user's permissions for the parent shared folder. :rtype: list of [MemberPermission] """ if self._permissions_present: return self._permissions_value else: raise AttributeError("missing required field 'permissions'") @permissions.setter def permissions(self, val): val = self._permissions_validator.validate(val) self._permissions_value = val self._permissions_present = True @permissions.deleter def permissions(self): self._permissions_value = None self._permissions_present = False @property def path(self): """ The full path to the parent shared folder relative to the acting user's root. :rtype: str """ if self._path_present: return self._path_value else: raise AttributeError("missing required field 'path'") @path.setter def path(self, val): val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False def __repr__(self): return 'ParentFolderAccessInfo(folder_name={!r}, shared_folder_id={!r}, permissions={!r}, path={!r})'.format( self._folder_name_value, self._shared_folder_id_value, self._permissions_value, self._path_value, ) ParentFolderAccessInfo_validator = bv.Struct(ParentFolderAccessInfo) class PathLinkMetadata(LinkMetadata): """ Metadata for a path-based shared link. :ivar path: Path in user's Dropbox. """ __slots__ = [ '_path_value', '_path_present', ] _has_required_fields = True def __init__(self, url=None, visibility=None, path=None, expires=None): super(PathLinkMetadata, self).__init__(url, visibility, expires) self._path_value = None self._path_present = False if path is not None: self.path = path @property def path(self): """ Path in user's Dropbox. :rtype: str """ if self._path_present: return self._path_value else: raise AttributeError("missing required field 'path'") @path.setter def path(self, val): val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False def __repr__(self): return 'PathLinkMetadata(url={!r}, visibility={!r}, path={!r}, expires={!r})'.format( self._url_value, self._visibility_value, self._path_value, self._expires_value, ) PathLinkMetadata_validator = bv.Struct(PathLinkMetadata) class PendingUploadMode(bb.Union): """ Flag to indicate pending upload default (for linking to not-yet-existing paths). This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar file: Assume pending uploads are files. :ivar folder: Assume pending uploads are folders. """ _catch_all = None # Attribute is overwritten below the class definition file = None # Attribute is overwritten below the class definition folder = None def is_file(self): """ Check if the union tag is ``file``. :rtype: bool """ return self._tag == 'file' def is_folder(self): """ Check if the union tag is ``folder``. :rtype: bool """ return self._tag == 'folder' def __repr__(self): return 'PendingUploadMode(%r, %r)' % (self._tag, self._value) PendingUploadMode_validator = bv.Union(PendingUploadMode) class PermissionDeniedReason(bb.Union): """ Possible reasons the user is denied a permission. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar user_not_same_team_as_owner: User is not on the same team as the folder owner. :ivar user_not_allowed_by_owner: User is prohibited by the owner from taking the action. :ivar target_is_indirect_member: Target is indirectly a member of the folder, for example by being part of a group. :ivar target_is_owner: Target is the owner of the folder. :ivar target_is_self: Target is the user itself. :ivar target_not_active: Target is not an active member of the team. :ivar folder_is_limited_team_folder: Folder is team folder for a limited team. :ivar owner_not_on_team: The content owner needs to be on a Dropbox team to perform this action. :ivar permission_denied: The user does not have permission to perform this action on the link. :ivar restricted_by_team: The user's team policy prevents performing this action on the link. :ivar user_account_type: The user's account type does not support this action. :ivar user_not_on_team: The user needs to be on a Dropbox team to perform this action. :ivar folder_is_inside_shared_folder: Folder is inside of another shared folder. :ivar restricted_by_parent_folder: Policy cannot be changed due to restrictions from parent folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition user_not_same_team_as_owner = None # Attribute is overwritten below the class definition user_not_allowed_by_owner = None # Attribute is overwritten below the class definition target_is_indirect_member = None # Attribute is overwritten below the class definition target_is_owner = None # Attribute is overwritten below the class definition target_is_self = None # Attribute is overwritten below the class definition target_not_active = None # Attribute is overwritten below the class definition folder_is_limited_team_folder = None # Attribute is overwritten below the class definition owner_not_on_team = None # Attribute is overwritten below the class definition permission_denied = None # Attribute is overwritten below the class definition restricted_by_team = None # Attribute is overwritten below the class definition user_account_type = None # Attribute is overwritten below the class definition user_not_on_team = None # Attribute is overwritten below the class definition folder_is_inside_shared_folder = None # Attribute is overwritten below the class definition restricted_by_parent_folder = None # Attribute is overwritten below the class definition other = None @classmethod def insufficient_plan(cls, val): """ Create an instance of this class set to the ``insufficient_plan`` tag with value ``val``. :param InsufficientPlan val: :rtype: PermissionDeniedReason """ return cls('insufficient_plan', val) def is_user_not_same_team_as_owner(self): """ Check if the union tag is ``user_not_same_team_as_owner``. :rtype: bool """ return self._tag == 'user_not_same_team_as_owner' def is_user_not_allowed_by_owner(self): """ Check if the union tag is ``user_not_allowed_by_owner``. :rtype: bool """ return self._tag == 'user_not_allowed_by_owner' def is_target_is_indirect_member(self): """ Check if the union tag is ``target_is_indirect_member``. :rtype: bool """ return self._tag == 'target_is_indirect_member' def is_target_is_owner(self): """ Check if the union tag is ``target_is_owner``. :rtype: bool """ return self._tag == 'target_is_owner' def is_target_is_self(self): """ Check if the union tag is ``target_is_self``. :rtype: bool """ return self._tag == 'target_is_self' def is_target_not_active(self): """ Check if the union tag is ``target_not_active``. :rtype: bool """ return self._tag == 'target_not_active' def is_folder_is_limited_team_folder(self): """ Check if the union tag is ``folder_is_limited_team_folder``. :rtype: bool """ return self._tag == 'folder_is_limited_team_folder' def is_owner_not_on_team(self): """ Check if the union tag is ``owner_not_on_team``. :rtype: bool """ return self._tag == 'owner_not_on_team' def is_permission_denied(self): """ Check if the union tag is ``permission_denied``. :rtype: bool """ return self._tag == 'permission_denied' def is_restricted_by_team(self): """ Check if the union tag is ``restricted_by_team``. :rtype: bool """ return self._tag == 'restricted_by_team' def is_user_account_type(self): """ Check if the union tag is ``user_account_type``. :rtype: bool """ return self._tag == 'user_account_type' def is_user_not_on_team(self): """ Check if the union tag is ``user_not_on_team``. :rtype: bool """ return self._tag == 'user_not_on_team' def is_folder_is_inside_shared_folder(self): """ Check if the union tag is ``folder_is_inside_shared_folder``. :rtype: bool """ return self._tag == 'folder_is_inside_shared_folder' def is_restricted_by_parent_folder(self): """ Check if the union tag is ``restricted_by_parent_folder``. :rtype: bool """ return self._tag == 'restricted_by_parent_folder' def is_insufficient_plan(self): """ Check if the union tag is ``insufficient_plan``. :rtype: bool """ return self._tag == 'insufficient_plan' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_insufficient_plan(self): """ Only call this if :meth:`is_insufficient_plan` is true. :rtype: InsufficientPlan """ if not self.is_insufficient_plan(): raise AttributeError("tag 'insufficient_plan' not set") return self._value def __repr__(self): return 'PermissionDeniedReason(%r, %r)' % (self._tag, self._value) PermissionDeniedReason_validator = bv.Union(PermissionDeniedReason) class RelinquishFileMembershipArg(object): """ :ivar file: The path or id for the file. """ __slots__ = [ '_file_value', '_file_present', ] _has_required_fields = True def __init__(self, file=None): self._file_value = None self._file_present = False if file is not None: self.file = file @property def file(self): """ The path or id for the file. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False def __repr__(self): return 'RelinquishFileMembershipArg(file={!r})'.format( self._file_value, ) RelinquishFileMembershipArg_validator = bv.Struct(RelinquishFileMembershipArg) class RelinquishFileMembershipError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar group_access: The current user has access to the shared file via a group. You can't relinquish membership to a file shared via groups. :ivar no_permission: The current user does not have permission to perform this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition group_access = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: RelinquishFileMembershipError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_group_access(self): """ Check if the union tag is ``group_access``. :rtype: bool """ return self._tag == 'group_access' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'RelinquishFileMembershipError(%r, %r)' % (self._tag, self._value) RelinquishFileMembershipError_validator = bv.Union(RelinquishFileMembershipError) class RelinquishFolderMembershipArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar leave_a_copy: Keep a copy of the folder's contents upon relinquishing membership. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_leave_a_copy_value', '_leave_a_copy_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, leave_a_copy=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._leave_a_copy_value = None self._leave_a_copy_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if leave_a_copy is not None: self.leave_a_copy = leave_a_copy @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def leave_a_copy(self): """ Keep a copy of the folder's contents upon relinquishing membership. :rtype: bool """ if self._leave_a_copy_present: return self._leave_a_copy_value else: return False @leave_a_copy.setter def leave_a_copy(self, val): val = self._leave_a_copy_validator.validate(val) self._leave_a_copy_value = val self._leave_a_copy_present = True @leave_a_copy.deleter def leave_a_copy(self): self._leave_a_copy_value = None self._leave_a_copy_present = False def __repr__(self): return 'RelinquishFolderMembershipArg(shared_folder_id={!r}, leave_a_copy={!r})'.format( self._shared_folder_id_value, self._leave_a_copy_value, ) RelinquishFolderMembershipArg_validator = bv.Struct(RelinquishFolderMembershipArg) class RelinquishFolderMembershipError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar folder_owner: The current user is the owner of the shared folder. Owners cannot relinquish membership to their own folders. Try unsharing or transferring ownership first. :ivar mounted: The shared folder is currently mounted. Unmount the shared folder before relinquishing membership. :ivar group_access: The current user has access to the shared folder via a group. You can't relinquish membership to folders shared via groups. :ivar team_folder: This action cannot be performed on a team shared folder. :ivar no_permission: The current user does not have permission to perform this action. :ivar no_explicit_access: The current user only has inherited access to the shared folder. You can't relinquish inherited membership to folders. """ _catch_all = 'other' # Attribute is overwritten below the class definition folder_owner = None # Attribute is overwritten below the class definition mounted = None # Attribute is overwritten below the class definition group_access = None # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition no_explicit_access = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: RelinquishFolderMembershipError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_folder_owner(self): """ Check if the union tag is ``folder_owner``. :rtype: bool """ return self._tag == 'folder_owner' def is_mounted(self): """ Check if the union tag is ``mounted``. :rtype: bool """ return self._tag == 'mounted' def is_group_access(self): """ Check if the union tag is ``group_access``. :rtype: bool """ return self._tag == 'group_access' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_no_explicit_access(self): """ Check if the union tag is ``no_explicit_access``. :rtype: bool """ return self._tag == 'no_explicit_access' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'RelinquishFolderMembershipError(%r, %r)' % (self._tag, self._value) RelinquishFolderMembershipError_validator = bv.Union(RelinquishFolderMembershipError) class RemoveFileMemberArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_remove_file_member_2`. :ivar file: File from which to remove members. :ivar member: Member to remove from this file. Note that even if an email is specified, it may result in the removal of a user (not an invitee) if the user's main account corresponds to that email address. """ __slots__ = [ '_file_value', '_file_present', '_member_value', '_member_present', ] _has_required_fields = True def __init__(self, file=None, member=None): self._file_value = None self._file_present = False self._member_value = None self._member_present = False if file is not None: self.file = file if member is not None: self.member = member @property def file(self): """ File from which to remove members. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False @property def member(self): """ Member to remove from this file. Note that even if an email is specified, it may result in the removal of a user (not an invitee) if the user's main account corresponds to that email address. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False def __repr__(self): return 'RemoveFileMemberArg(file={!r}, member={!r})'.format( self._file_value, self._member_value, ) RemoveFileMemberArg_validator = bv.Struct(RemoveFileMemberArg) class RemoveFileMemberError(bb.Union): """ Errors for :meth:`dropbox.dropbox.Dropbox.sharing_remove_file_member_2`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar MemberAccessLevelResult no_explicit_access: This member does not have explicit access to the file and therefore cannot be removed. The return value is the access that a user might have to the file from a parent folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: RemoveFileMemberError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: RemoveFileMemberError """ return cls('access_error', val) @classmethod def no_explicit_access(cls, val): """ Create an instance of this class set to the ``no_explicit_access`` tag with value ``val``. :param MemberAccessLevelResult val: :rtype: RemoveFileMemberError """ return cls('no_explicit_access', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_no_explicit_access(self): """ Check if the union tag is ``no_explicit_access``. :rtype: bool """ return self._tag == 'no_explicit_access' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_no_explicit_access(self): """ This member does not have explicit access to the file and therefore cannot be removed. The return value is the access that a user might have to the file from a parent folder. Only call this if :meth:`is_no_explicit_access` is true. :rtype: MemberAccessLevelResult """ if not self.is_no_explicit_access(): raise AttributeError("tag 'no_explicit_access' not set") return self._value def __repr__(self): return 'RemoveFileMemberError(%r, %r)' % (self._tag, self._value) RemoveFileMemberError_validator = bv.Union(RemoveFileMemberError) class RemoveFolderMemberArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar member: The member to remove from the folder. :ivar leave_a_copy: If true, the removed user will keep their copy of the folder after it's unshared, assuming it was mounted. Otherwise, it will be removed from their Dropbox. Also, this must be set to false when kicking a group. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_member_value', '_member_present', '_leave_a_copy_value', '_leave_a_copy_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, member=None, leave_a_copy=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._member_value = None self._member_present = False self._leave_a_copy_value = None self._leave_a_copy_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if member is not None: self.member = member if leave_a_copy is not None: self.leave_a_copy = leave_a_copy @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def member(self): """ The member to remove from the folder. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False @property def leave_a_copy(self): """ If true, the removed user will keep their copy of the folder after it's unshared, assuming it was mounted. Otherwise, it will be removed from their Dropbox. Also, this must be set to false when kicking a group. :rtype: bool """ if self._leave_a_copy_present: return self._leave_a_copy_value else: raise AttributeError("missing required field 'leave_a_copy'") @leave_a_copy.setter def leave_a_copy(self, val): val = self._leave_a_copy_validator.validate(val) self._leave_a_copy_value = val self._leave_a_copy_present = True @leave_a_copy.deleter def leave_a_copy(self): self._leave_a_copy_value = None self._leave_a_copy_present = False def __repr__(self): return 'RemoveFolderMemberArg(shared_folder_id={!r}, member={!r}, leave_a_copy={!r})'.format( self._shared_folder_id_value, self._member_value, self._leave_a_copy_value, ) RemoveFolderMemberArg_validator = bv.Struct(RemoveFolderMemberArg) class RemoveFolderMemberError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar folder_owner: The target user is the owner of the shared folder. You can't remove this user until ownership has been transferred to another member. :ivar group_access: The target user has access to the shared folder via a group. :ivar team_folder: This action cannot be performed on a team shared folder. :ivar no_permission: The current user does not have permission to perform this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition folder_owner = None # Attribute is overwritten below the class definition group_access = None # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: RemoveFolderMemberError """ return cls('access_error', val) @classmethod def member_error(cls, val): """ Create an instance of this class set to the ``member_error`` tag with value ``val``. :param SharedFolderMemberError val: :rtype: RemoveFolderMemberError """ return cls('member_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_member_error(self): """ Check if the union tag is ``member_error``. :rtype: bool """ return self._tag == 'member_error' def is_folder_owner(self): """ Check if the union tag is ``folder_owner``. :rtype: bool """ return self._tag == 'folder_owner' def is_group_access(self): """ Check if the union tag is ``group_access``. :rtype: bool """ return self._tag == 'group_access' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_member_error(self): """ Only call this if :meth:`is_member_error` is true. :rtype: SharedFolderMemberError """ if not self.is_member_error(): raise AttributeError("tag 'member_error' not set") return self._value def __repr__(self): return 'RemoveFolderMemberError(%r, %r)' % (self._tag, self._value) RemoveFolderMemberError_validator = bv.Union(RemoveFolderMemberError) class RemoveMemberJobStatus(async.PollResultBase): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar MemberAccessLevelResult complete: Removing the folder member has finished. The value is information about whether the member has another form of access. """ @classmethod def complete(cls, val): """ Create an instance of this class set to the ``complete`` tag with value ``val``. :param MemberAccessLevelResult val: :rtype: RemoveMemberJobStatus """ return cls('complete', val) @classmethod def failed(cls, val): """ Create an instance of this class set to the ``failed`` tag with value ``val``. :param RemoveFolderMemberError val: :rtype: RemoveMemberJobStatus """ return cls('failed', val) def is_complete(self): """ Check if the union tag is ``complete``. :rtype: bool """ return self._tag == 'complete' def is_failed(self): """ Check if the union tag is ``failed``. :rtype: bool """ return self._tag == 'failed' def get_complete(self): """ Removing the folder member has finished. The value is information about whether the member has another form of access. Only call this if :meth:`is_complete` is true. :rtype: MemberAccessLevelResult """ if not self.is_complete(): raise AttributeError("tag 'complete' not set") return self._value def get_failed(self): """ Only call this if :meth:`is_failed` is true. :rtype: RemoveFolderMemberError """ if not self.is_failed(): raise AttributeError("tag 'failed' not set") return self._value def __repr__(self): return 'RemoveMemberJobStatus(%r, %r)' % (self._tag, self._value) RemoveMemberJobStatus_validator = bv.Union(RemoveMemberJobStatus) class RequestedVisibility(bb.Union): """ The access permission that can be requested by the caller for the shared link. Note that the final resolved visibility of the shared link takes into account other aspects, such as team and shared folder settings. Check the :class:`ResolvedVisibility` for more info on the possible resolved visibility values of shared links. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar public: Anyone who has received the link can access it. No login required. :ivar team_only: Only members of the same team can access the link. Login is required. :ivar password: A link-specific password is required to access the link. Login is not required. """ _catch_all = None # Attribute is overwritten below the class definition public = None # Attribute is overwritten below the class definition team_only = None # Attribute is overwritten below the class definition password = None def is_public(self): """ Check if the union tag is ``public``. :rtype: bool """ return self._tag == 'public' def is_team_only(self): """ Check if the union tag is ``team_only``. :rtype: bool """ return self._tag == 'team_only' def is_password(self): """ Check if the union tag is ``password``. :rtype: bool """ return self._tag == 'password' def __repr__(self): return 'RequestedVisibility(%r, %r)' % (self._tag, self._value) RequestedVisibility_validator = bv.Union(RequestedVisibility) class ResolvedVisibility(RequestedVisibility): """ The actual access permissions values of shared links after taking into account user preferences and the team and shared folder settings. Check the :class:`RequestedVisibility` for more info on the possible visibility values that can be set by the shared link's owner. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar team_and_password: Only members of the same team who have the link-specific password can access the link. Login is required. :ivar shared_folder_only: Only members of the shared folder containing the linked file can access the link. Login is required. """ _catch_all = 'other' # Attribute is overwritten below the class definition team_and_password = None # Attribute is overwritten below the class definition shared_folder_only = None # Attribute is overwritten below the class definition other = None def is_team_and_password(self): """ Check if the union tag is ``team_and_password``. :rtype: bool """ return self._tag == 'team_and_password' def is_shared_folder_only(self): """ Check if the union tag is ``shared_folder_only``. :rtype: bool """ return self._tag == 'shared_folder_only' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'ResolvedVisibility(%r, %r)' % (self._tag, self._value) ResolvedVisibility_validator = bv.Union(ResolvedVisibility) class RevokeSharedLinkArg(object): """ :ivar url: URL of the shared link. """ __slots__ = [ '_url_value', '_url_present', ] _has_required_fields = True def __init__(self, url=None): self._url_value = None self._url_present = False if url is not None: self.url = url @property def url(self): """ URL of the shared link. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False def __repr__(self): return 'RevokeSharedLinkArg(url={!r})'.format( self._url_value, ) RevokeSharedLinkArg_validator = bv.Struct(RevokeSharedLinkArg) class RevokeSharedLinkError(SharedLinkError): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar shared_link_malformed: Shared link is malformed. """ # Attribute is overwritten below the class definition shared_link_malformed = None def is_shared_link_malformed(self): """ Check if the union tag is ``shared_link_malformed``. :rtype: bool """ return self._tag == 'shared_link_malformed' def __repr__(self): return 'RevokeSharedLinkError(%r, %r)' % (self._tag, self._value) RevokeSharedLinkError_validator = bv.Union(RevokeSharedLinkError) class ShareFolderArgBase(object): """ :ivar acl_update_policy: Who can add and remove members of this shared folder. :ivar force_async: Whether to force the share to happen asynchronously. :ivar member_policy: Who can be a member of this shared folder. Only applicable if the current user is on a team. :ivar path: The path to the folder to share. If it does not exist, then a new one is created. :ivar shared_link_policy: The policy to apply to shared links created for content inside this shared folder. The current user must be on a team to set this policy to ``SharedLinkPolicy.members``. :ivar viewer_info_policy: Who can enable/disable viewer info for this shared folder. """ __slots__ = [ '_acl_update_policy_value', '_acl_update_policy_present', '_force_async_value', '_force_async_present', '_member_policy_value', '_member_policy_present', '_path_value', '_path_present', '_shared_link_policy_value', '_shared_link_policy_present', '_viewer_info_policy_value', '_viewer_info_policy_present', ] _has_required_fields = True def __init__(self, path=None, acl_update_policy=None, force_async=None, member_policy=None, shared_link_policy=None, viewer_info_policy=None): self._acl_update_policy_value = None self._acl_update_policy_present = False self._force_async_value = None self._force_async_present = False self._member_policy_value = None self._member_policy_present = False self._path_value = None self._path_present = False self._shared_link_policy_value = None self._shared_link_policy_present = False self._viewer_info_policy_value = None self._viewer_info_policy_present = False if acl_update_policy is not None: self.acl_update_policy = acl_update_policy if force_async is not None: self.force_async = force_async if member_policy is not None: self.member_policy = member_policy if path is not None: self.path = path if shared_link_policy is not None: self.shared_link_policy = shared_link_policy if viewer_info_policy is not None: self.viewer_info_policy = viewer_info_policy @property def acl_update_policy(self): """ Who can add and remove members of this shared folder. :rtype: AclUpdatePolicy """ if self._acl_update_policy_present: return self._acl_update_policy_value else: return None @acl_update_policy.setter def acl_update_policy(self, val): if val is None: del self.acl_update_policy return self._acl_update_policy_validator.validate_type_only(val) self._acl_update_policy_value = val self._acl_update_policy_present = True @acl_update_policy.deleter def acl_update_policy(self): self._acl_update_policy_value = None self._acl_update_policy_present = False @property def force_async(self): """ Whether to force the share to happen asynchronously. :rtype: bool """ if self._force_async_present: return self._force_async_value else: return False @force_async.setter def force_async(self, val): val = self._force_async_validator.validate(val) self._force_async_value = val self._force_async_present = True @force_async.deleter def force_async(self): self._force_async_value = None self._force_async_present = False @property def member_policy(self): """ Who can be a member of this shared folder. Only applicable if the current user is on a team. :rtype: MemberPolicy """ if self._member_policy_present: return self._member_policy_value else: return None @member_policy.setter def member_policy(self, val): if val is None: del self.member_policy return self._member_policy_validator.validate_type_only(val) self._member_policy_value = val self._member_policy_present = True @member_policy.deleter def member_policy(self): self._member_policy_value = None self._member_policy_present = False @property def path(self): """ The path to the folder to share. If it does not exist, then a new one is created. :rtype: str """ if self._path_present: return self._path_value else: raise AttributeError("missing required field 'path'") @path.setter def path(self, val): val = self._path_validator.validate(val) self._path_value = val self._path_present = True @path.deleter def path(self): self._path_value = None self._path_present = False @property def shared_link_policy(self): """ The policy to apply to shared links created for content inside this shared folder. The current user must be on a team to set this policy to ``SharedLinkPolicy.members``. :rtype: SharedLinkPolicy """ if self._shared_link_policy_present: return self._shared_link_policy_value else: return None @shared_link_policy.setter def shared_link_policy(self, val): if val is None: del self.shared_link_policy return self._shared_link_policy_validator.validate_type_only(val) self._shared_link_policy_value = val self._shared_link_policy_present = True @shared_link_policy.deleter def shared_link_policy(self): self._shared_link_policy_value = None self._shared_link_policy_present = False @property def viewer_info_policy(self): """ Who can enable/disable viewer info for this shared folder. :rtype: ViewerInfoPolicy """ if self._viewer_info_policy_present: return self._viewer_info_policy_value else: return None @viewer_info_policy.setter def viewer_info_policy(self, val): if val is None: del self.viewer_info_policy return self._viewer_info_policy_validator.validate_type_only(val) self._viewer_info_policy_value = val self._viewer_info_policy_present = True @viewer_info_policy.deleter def viewer_info_policy(self): self._viewer_info_policy_value = None self._viewer_info_policy_present = False def __repr__(self): return 'ShareFolderArgBase(path={!r}, acl_update_policy={!r}, force_async={!r}, member_policy={!r}, shared_link_policy={!r}, viewer_info_policy={!r})'.format( self._path_value, self._acl_update_policy_value, self._force_async_value, self._member_policy_value, self._shared_link_policy_value, self._viewer_info_policy_value, ) ShareFolderArgBase_validator = bv.Struct(ShareFolderArgBase) class ShareFolderArg(ShareFolderArgBase): """ :ivar actions: A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. :ivar link_settings: Settings on the link for this folder. """ __slots__ = [ '_actions_value', '_actions_present', '_link_settings_value', '_link_settings_present', ] _has_required_fields = True def __init__(self, path=None, acl_update_policy=None, force_async=None, member_policy=None, shared_link_policy=None, viewer_info_policy=None, actions=None, link_settings=None): super(ShareFolderArg, self).__init__(path, acl_update_policy, force_async, member_policy, shared_link_policy, viewer_info_policy) self._actions_value = None self._actions_present = False self._link_settings_value = None self._link_settings_present = False if actions is not None: self.actions = actions if link_settings is not None: self.link_settings = link_settings @property def actions(self): """ A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. :rtype: list of [FolderAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False @property def link_settings(self): """ Settings on the link for this folder. :rtype: LinkSettings """ if self._link_settings_present: return self._link_settings_value else: return None @link_settings.setter def link_settings(self, val): if val is None: del self.link_settings return self._link_settings_validator.validate_type_only(val) self._link_settings_value = val self._link_settings_present = True @link_settings.deleter def link_settings(self): self._link_settings_value = None self._link_settings_present = False def __repr__(self): return 'ShareFolderArg(path={!r}, acl_update_policy={!r}, force_async={!r}, member_policy={!r}, shared_link_policy={!r}, viewer_info_policy={!r}, actions={!r}, link_settings={!r})'.format( self._path_value, self._acl_update_policy_value, self._force_async_value, self._member_policy_value, self._shared_link_policy_value, self._viewer_info_policy_value, self._actions_value, self._link_settings_value, ) ShareFolderArg_validator = bv.Struct(ShareFolderArg) class ShareFolderErrorBase(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar email_unverified: The current user's e-mail address is unverified. :ivar SharePathError bad_path: ``ShareFolderArg.path`` is invalid. :ivar team_policy_disallows_member_policy: Team policy is more restrictive than ``ShareFolderArg.member_policy``. :ivar disallowed_shared_link_policy: The current user's account is not allowed to select the specified ``ShareFolderArg.shared_link_policy``. """ _catch_all = 'other' # Attribute is overwritten below the class definition email_unverified = None # Attribute is overwritten below the class definition team_policy_disallows_member_policy = None # Attribute is overwritten below the class definition disallowed_shared_link_policy = None # Attribute is overwritten below the class definition other = None @classmethod def bad_path(cls, val): """ Create an instance of this class set to the ``bad_path`` tag with value ``val``. :param SharePathError val: :rtype: ShareFolderErrorBase """ return cls('bad_path', val) def is_email_unverified(self): """ Check if the union tag is ``email_unverified``. :rtype: bool """ return self._tag == 'email_unverified' def is_bad_path(self): """ Check if the union tag is ``bad_path``. :rtype: bool """ return self._tag == 'bad_path' def is_team_policy_disallows_member_policy(self): """ Check if the union tag is ``team_policy_disallows_member_policy``. :rtype: bool """ return self._tag == 'team_policy_disallows_member_policy' def is_disallowed_shared_link_policy(self): """ Check if the union tag is ``disallowed_shared_link_policy``. :rtype: bool """ return self._tag == 'disallowed_shared_link_policy' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_bad_path(self): """ ``ShareFolderArg.path`` is invalid. Only call this if :meth:`is_bad_path` is true. :rtype: SharePathError """ if not self.is_bad_path(): raise AttributeError("tag 'bad_path' not set") return self._value def __repr__(self): return 'ShareFolderErrorBase(%r, %r)' % (self._tag, self._value) ShareFolderErrorBase_validator = bv.Union(ShareFolderErrorBase) class ShareFolderError(ShareFolderErrorBase): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar no_permission: The current user does not have permission to perform this action. """ # Attribute is overwritten below the class definition no_permission = None def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def __repr__(self): return 'ShareFolderError(%r, %r)' % (self._tag, self._value) ShareFolderError_validator = bv.Union(ShareFolderError) class ShareFolderJobStatus(async.PollResultBase): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar SharedFolderMetadata complete: The share job has finished. The value is the metadata for the folder. """ @classmethod def complete(cls, val): """ Create an instance of this class set to the ``complete`` tag with value ``val``. :param SharedFolderMetadata val: :rtype: ShareFolderJobStatus """ return cls('complete', val) @classmethod def failed(cls, val): """ Create an instance of this class set to the ``failed`` tag with value ``val``. :param ShareFolderError val: :rtype: ShareFolderJobStatus """ return cls('failed', val) def is_complete(self): """ Check if the union tag is ``complete``. :rtype: bool """ return self._tag == 'complete' def is_failed(self): """ Check if the union tag is ``failed``. :rtype: bool """ return self._tag == 'failed' def get_complete(self): """ The share job has finished. The value is the metadata for the folder. Only call this if :meth:`is_complete` is true. :rtype: SharedFolderMetadata """ if not self.is_complete(): raise AttributeError("tag 'complete' not set") return self._value def get_failed(self): """ Only call this if :meth:`is_failed` is true. :rtype: ShareFolderError """ if not self.is_failed(): raise AttributeError("tag 'failed' not set") return self._value def __repr__(self): return 'ShareFolderJobStatus(%r, %r)' % (self._tag, self._value) ShareFolderJobStatus_validator = bv.Union(ShareFolderJobStatus) class ShareFolderLaunch(async.LaunchResultBase): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ @classmethod def complete(cls, val): """ Create an instance of this class set to the ``complete`` tag with value ``val``. :param SharedFolderMetadata val: :rtype: ShareFolderLaunch """ return cls('complete', val) def is_complete(self): """ Check if the union tag is ``complete``. :rtype: bool """ return self._tag == 'complete' def get_complete(self): """ Only call this if :meth:`is_complete` is true. :rtype: SharedFolderMetadata """ if not self.is_complete(): raise AttributeError("tag 'complete' not set") return self._value def __repr__(self): return 'ShareFolderLaunch(%r, %r)' % (self._tag, self._value) ShareFolderLaunch_validator = bv.Union(ShareFolderLaunch) class SharePathError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar is_file: A file is at the specified path. :ivar inside_shared_folder: We do not support sharing a folder inside a shared folder. :ivar contains_shared_folder: We do not support shared folders that contain shared folders. :ivar contains_app_folder: We do not support shared folders that contain app folders. :ivar contains_team_folder: We do not support shared folders that contain team folders. :ivar is_app_folder: We do not support sharing an app folder. :ivar inside_app_folder: We do not support sharing a folder inside an app folder. :ivar is_public_folder: A public folder can't be shared this way. Use a public link instead. :ivar inside_public_folder: A folder inside a public folder can't be shared this way. Use a public link instead. :ivar SharedFolderMetadata already_shared: Folder is already shared. Contains metadata about the existing shared folder. :ivar invalid_path: Path is not valid. :ivar is_osx_package: We do not support sharing a Mac OS X package. :ivar inside_osx_package: We do not support sharing a folder inside a Mac OS X package. """ _catch_all = 'other' # Attribute is overwritten below the class definition is_file = None # Attribute is overwritten below the class definition inside_shared_folder = None # Attribute is overwritten below the class definition contains_shared_folder = None # Attribute is overwritten below the class definition contains_app_folder = None # Attribute is overwritten below the class definition contains_team_folder = None # Attribute is overwritten below the class definition is_app_folder = None # Attribute is overwritten below the class definition inside_app_folder = None # Attribute is overwritten below the class definition is_public_folder = None # Attribute is overwritten below the class definition inside_public_folder = None # Attribute is overwritten below the class definition invalid_path = None # Attribute is overwritten below the class definition is_osx_package = None # Attribute is overwritten below the class definition inside_osx_package = None # Attribute is overwritten below the class definition other = None @classmethod def already_shared(cls, val): """ Create an instance of this class set to the ``already_shared`` tag with value ``val``. :param SharedFolderMetadata val: :rtype: SharePathError """ return cls('already_shared', val) def is_is_file(self): """ Check if the union tag is ``is_file``. :rtype: bool """ return self._tag == 'is_file' def is_inside_shared_folder(self): """ Check if the union tag is ``inside_shared_folder``. :rtype: bool """ return self._tag == 'inside_shared_folder' def is_contains_shared_folder(self): """ Check if the union tag is ``contains_shared_folder``. :rtype: bool """ return self._tag == 'contains_shared_folder' def is_contains_app_folder(self): """ Check if the union tag is ``contains_app_folder``. :rtype: bool """ return self._tag == 'contains_app_folder' def is_contains_team_folder(self): """ Check if the union tag is ``contains_team_folder``. :rtype: bool """ return self._tag == 'contains_team_folder' def is_is_app_folder(self): """ Check if the union tag is ``is_app_folder``. :rtype: bool """ return self._tag == 'is_app_folder' def is_inside_app_folder(self): """ Check if the union tag is ``inside_app_folder``. :rtype: bool """ return self._tag == 'inside_app_folder' def is_is_public_folder(self): """ Check if the union tag is ``is_public_folder``. :rtype: bool """ return self._tag == 'is_public_folder' def is_inside_public_folder(self): """ Check if the union tag is ``inside_public_folder``. :rtype: bool """ return self._tag == 'inside_public_folder' def is_already_shared(self): """ Check if the union tag is ``already_shared``. :rtype: bool """ return self._tag == 'already_shared' def is_invalid_path(self): """ Check if the union tag is ``invalid_path``. :rtype: bool """ return self._tag == 'invalid_path' def is_is_osx_package(self): """ Check if the union tag is ``is_osx_package``. :rtype: bool """ return self._tag == 'is_osx_package' def is_inside_osx_package(self): """ Check if the union tag is ``inside_osx_package``. :rtype: bool """ return self._tag == 'inside_osx_package' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_already_shared(self): """ Folder is already shared. Contains metadata about the existing shared folder. Only call this if :meth:`is_already_shared` is true. :rtype: SharedFolderMetadata """ if not self.is_already_shared(): raise AttributeError("tag 'already_shared' not set") return self._value def __repr__(self): return 'SharePathError(%r, %r)' % (self._tag, self._value) SharePathError_validator = bv.Union(SharePathError) class SharedContentLinkMetadata(SharedContentLinkMetadataBase): """ Metadata of a shared link for a file or folder. :ivar audience_exceptions: The content inside this folder with link audience different than this folder's. This is only returned when an endpoint that returns metadata for a single shared folder is called, e.g. /get_folder_metadata. :ivar url: The URL of the link. """ __slots__ = [ '_audience_exceptions_value', '_audience_exceptions_present', '_url_value', '_url_present', ] _has_required_fields = True def __init__(self, audience_options=None, current_audience=None, link_permissions=None, password_protected=None, url=None, access_level=None, audience_restricting_shared_folder=None, expiry=None, audience_exceptions=None): super(SharedContentLinkMetadata, self).__init__(audience_options, current_audience, link_permissions, password_protected, access_level, audience_restricting_shared_folder, expiry) self._audience_exceptions_value = None self._audience_exceptions_present = False self._url_value = None self._url_present = False if audience_exceptions is not None: self.audience_exceptions = audience_exceptions if url is not None: self.url = url @property def audience_exceptions(self): """ The content inside this folder with link audience different than this folder's. This is only returned when an endpoint that returns metadata for a single shared folder is called, e.g. /get_folder_metadata. :rtype: AudienceExceptions """ if self._audience_exceptions_present: return self._audience_exceptions_value else: return None @audience_exceptions.setter def audience_exceptions(self, val): if val is None: del self.audience_exceptions return self._audience_exceptions_validator.validate_type_only(val) self._audience_exceptions_value = val self._audience_exceptions_present = True @audience_exceptions.deleter def audience_exceptions(self): self._audience_exceptions_value = None self._audience_exceptions_present = False @property def url(self): """ The URL of the link. :rtype: str """ if self._url_present: return self._url_value else: raise AttributeError("missing required field 'url'") @url.setter def url(self, val): val = self._url_validator.validate(val) self._url_value = val self._url_present = True @url.deleter def url(self): self._url_value = None self._url_present = False def __repr__(self): return 'SharedContentLinkMetadata(audience_options={!r}, current_audience={!r}, link_permissions={!r}, password_protected={!r}, url={!r}, access_level={!r}, audience_restricting_shared_folder={!r}, expiry={!r}, audience_exceptions={!r})'.format( self._audience_options_value, self._current_audience_value, self._link_permissions_value, self._password_protected_value, self._url_value, self._access_level_value, self._audience_restricting_shared_folder_value, self._expiry_value, self._audience_exceptions_value, ) SharedContentLinkMetadata_validator = bv.Struct(SharedContentLinkMetadata) class SharedFileMembers(object): """ Shared file user, group, and invitee membership. Used for the results of :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members` and :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`, and used as part of the results for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`. :ivar users: The list of user members of the shared file. :ivar groups: The list of group members of the shared file. :ivar invitees: The list of invited members of a file, but have not logged in and claimed this. :ivar cursor: Present if there are additional shared file members that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue` to list additional members. """ __slots__ = [ '_users_value', '_users_present', '_groups_value', '_groups_present', '_invitees_value', '_invitees_present', '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, users=None, groups=None, invitees=None, cursor=None): self._users_value = None self._users_present = False self._groups_value = None self._groups_present = False self._invitees_value = None self._invitees_present = False self._cursor_value = None self._cursor_present = False if users is not None: self.users = users if groups is not None: self.groups = groups if invitees is not None: self.invitees = invitees if cursor is not None: self.cursor = cursor @property def users(self): """ The list of user members of the shared file. :rtype: list of [UserFileMembershipInfo] """ if self._users_present: return self._users_value else: raise AttributeError("missing required field 'users'") @users.setter def users(self, val): val = self._users_validator.validate(val) self._users_value = val self._users_present = True @users.deleter def users(self): self._users_value = None self._users_present = False @property def groups(self): """ The list of group members of the shared file. :rtype: list of [GroupMembershipInfo] """ if self._groups_present: return self._groups_value else: raise AttributeError("missing required field 'groups'") @groups.setter def groups(self, val): val = self._groups_validator.validate(val) self._groups_value = val self._groups_present = True @groups.deleter def groups(self): self._groups_value = None self._groups_present = False @property def invitees(self): """ The list of invited members of a file, but have not logged in and claimed this. :rtype: list of [InviteeMembershipInfo] """ if self._invitees_present: return self._invitees_value else: raise AttributeError("missing required field 'invitees'") @invitees.setter def invitees(self, val): val = self._invitees_validator.validate(val) self._invitees_value = val self._invitees_present = True @invitees.deleter def invitees(self): self._invitees_value = None self._invitees_present = False @property def cursor(self): """ Present if there are additional shared file members that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue` to list additional members. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'SharedFileMembers(users={!r}, groups={!r}, invitees={!r}, cursor={!r})'.format( self._users_value, self._groups_value, self._invitees_value, self._cursor_value, ) SharedFileMembers_validator = bv.Struct(SharedFileMembers) class SharedFileMetadata(object): """ Properties of the shared file. :ivar access_type: The current user's access level for this shared file. :ivar id: The ID of the file. :ivar expected_link_metadata: The expected metadata of the link associated for the file when it is first shared. Absent if the link already exists. This is for an unreleased feature so it may not be returned yet. :ivar link_metadata: The metadata of the link associated for the file. This is for an unreleased feature so it may not be returned yet. :ivar name: The name of this file. :ivar owner_display_names: The display names of the users that own the file. If the file is part of a team folder, the display names of the team admins are also included. Absent if the owner display names cannot be fetched. :ivar owner_team: The team that owns the file. This field is not present if the file is not owned by a team. :ivar parent_shared_folder_id: The ID of the parent shared folder. This field is present only if the file is contained within a shared folder. :ivar path_display: The cased path to be used for display purposes only. In rare instances the casing will not correctly match the user's filesystem, but this behavior will match the path provided in the Core API v1. Absent for unmounted files. :ivar path_lower: The lower-case full path of this file. Absent for unmounted files. :ivar permissions: The sharing permissions that requesting user has on this file. This corresponds to the entries given in ``GetFileMetadataBatchArg.actions`` or ``GetFileMetadataArg.actions``. :ivar policy: Policies governing this shared file. :ivar preview_url: URL for displaying a web preview of the shared file. :ivar time_invited: Timestamp indicating when the current user was invited to this shared file. If the user was not invited to the shared file, the timestamp will indicate when the user was invited to the parent shared folder. This value may be absent. """ __slots__ = [ '_access_type_value', '_access_type_present', '_id_value', '_id_present', '_expected_link_metadata_value', '_expected_link_metadata_present', '_link_metadata_value', '_link_metadata_present', '_name_value', '_name_present', '_owner_display_names_value', '_owner_display_names_present', '_owner_team_value', '_owner_team_present', '_parent_shared_folder_id_value', '_parent_shared_folder_id_present', '_path_display_value', '_path_display_present', '_path_lower_value', '_path_lower_present', '_permissions_value', '_permissions_present', '_policy_value', '_policy_present', '_preview_url_value', '_preview_url_present', '_time_invited_value', '_time_invited_present', ] _has_required_fields = True def __init__(self, id=None, name=None, policy=None, preview_url=None, access_type=None, expected_link_metadata=None, link_metadata=None, owner_display_names=None, owner_team=None, parent_shared_folder_id=None, path_display=None, path_lower=None, permissions=None, time_invited=None): self._access_type_value = None self._access_type_present = False self._id_value = None self._id_present = False self._expected_link_metadata_value = None self._expected_link_metadata_present = False self._link_metadata_value = None self._link_metadata_present = False self._name_value = None self._name_present = False self._owner_display_names_value = None self._owner_display_names_present = False self._owner_team_value = None self._owner_team_present = False self._parent_shared_folder_id_value = None self._parent_shared_folder_id_present = False self._path_display_value = None self._path_display_present = False self._path_lower_value = None self._path_lower_present = False self._permissions_value = None self._permissions_present = False self._policy_value = None self._policy_present = False self._preview_url_value = None self._preview_url_present = False self._time_invited_value = None self._time_invited_present = False if access_type is not None: self.access_type = access_type if id is not None: self.id = id if expected_link_metadata is not None: self.expected_link_metadata = expected_link_metadata if link_metadata is not None: self.link_metadata = link_metadata if name is not None: self.name = name if owner_display_names is not None: self.owner_display_names = owner_display_names if owner_team is not None: self.owner_team = owner_team if parent_shared_folder_id is not None: self.parent_shared_folder_id = parent_shared_folder_id if path_display is not None: self.path_display = path_display if path_lower is not None: self.path_lower = path_lower if permissions is not None: self.permissions = permissions if policy is not None: self.policy = policy if preview_url is not None: self.preview_url = preview_url if time_invited is not None: self.time_invited = time_invited @property def access_type(self): """ The current user's access level for this shared file. :rtype: AccessLevel """ if self._access_type_present: return self._access_type_value else: return None @access_type.setter def access_type(self, val): if val is None: del self.access_type return self._access_type_validator.validate_type_only(val) self._access_type_value = val self._access_type_present = True @access_type.deleter def access_type(self): self._access_type_value = None self._access_type_present = False @property def id(self): """ The ID of the file. :rtype: str """ if self._id_present: return self._id_value else: raise AttributeError("missing required field 'id'") @id.setter def id(self, val): val = self._id_validator.validate(val) self._id_value = val self._id_present = True @id.deleter def id(self): self._id_value = None self._id_present = False @property def expected_link_metadata(self): """ The expected metadata of the link associated for the file when it is first shared. Absent if the link already exists. This is for an unreleased feature so it may not be returned yet. :rtype: ExpectedSharedContentLinkMetadata """ if self._expected_link_metadata_present: return self._expected_link_metadata_value else: return None @expected_link_metadata.setter def expected_link_metadata(self, val): if val is None: del self.expected_link_metadata return self._expected_link_metadata_validator.validate_type_only(val) self._expected_link_metadata_value = val self._expected_link_metadata_present = True @expected_link_metadata.deleter def expected_link_metadata(self): self._expected_link_metadata_value = None self._expected_link_metadata_present = False @property def link_metadata(self): """ The metadata of the link associated for the file. This is for an unreleased feature so it may not be returned yet. :rtype: SharedContentLinkMetadata """ if self._link_metadata_present: return self._link_metadata_value else: return None @link_metadata.setter def link_metadata(self, val): if val is None: del self.link_metadata return self._link_metadata_validator.validate_type_only(val) self._link_metadata_value = val self._link_metadata_present = True @link_metadata.deleter def link_metadata(self): self._link_metadata_value = None self._link_metadata_present = False @property def name(self): """ The name of this file. :rtype: str """ if self._name_present: return self._name_value else: raise AttributeError("missing required field 'name'") @name.setter def name(self, val): val = self._name_validator.validate(val) self._name_value = val self._name_present = True @name.deleter def name(self): self._name_value = None self._name_present = False @property def owner_display_names(self): """ The display names of the users that own the file. If the file is part of a team folder, the display names of the team admins are also included. Absent if the owner display names cannot be fetched. :rtype: list of [str] """ if self._owner_display_names_present: return self._owner_display_names_value else: return None @owner_display_names.setter def owner_display_names(self, val): if val is None: del self.owner_display_names return val = self._owner_display_names_validator.validate(val) self._owner_display_names_value = val self._owner_display_names_present = True @owner_display_names.deleter def owner_display_names(self): self._owner_display_names_value = None self._owner_display_names_present = False @property def owner_team(self): """ The team that owns the file. This field is not present if the file is not owned by a team. :rtype: users.Team_validator """ if self._owner_team_present: return self._owner_team_value else: return None @owner_team.setter def owner_team(self, val): if val is None: del self.owner_team return self._owner_team_validator.validate_type_only(val) self._owner_team_value = val self._owner_team_present = True @owner_team.deleter def owner_team(self): self._owner_team_value = None self._owner_team_present = False @property def parent_shared_folder_id(self): """ The ID of the parent shared folder. This field is present only if the file is contained within a shared folder. :rtype: str """ if self._parent_shared_folder_id_present: return self._parent_shared_folder_id_value else: return None @parent_shared_folder_id.setter def parent_shared_folder_id(self, val): if val is None: del self.parent_shared_folder_id return val = self._parent_shared_folder_id_validator.validate(val) self._parent_shared_folder_id_value = val self._parent_shared_folder_id_present = True @parent_shared_folder_id.deleter def parent_shared_folder_id(self): self._parent_shared_folder_id_value = None self._parent_shared_folder_id_present = False @property def path_display(self): """ The cased path to be used for display purposes only. In rare instances the casing will not correctly match the user's filesystem, but this behavior will match the path provided in the Core API v1. Absent for unmounted files. :rtype: str """ if self._path_display_present: return self._path_display_value else: return None @path_display.setter def path_display(self, val): if val is None: del self.path_display return val = self._path_display_validator.validate(val) self._path_display_value = val self._path_display_present = True @path_display.deleter def path_display(self): self._path_display_value = None self._path_display_present = False @property def path_lower(self): """ The lower-case full path of this file. Absent for unmounted files. :rtype: str """ if self._path_lower_present: return self._path_lower_value else: return None @path_lower.setter def path_lower(self, val): if val is None: del self.path_lower return val = self._path_lower_validator.validate(val) self._path_lower_value = val self._path_lower_present = True @path_lower.deleter def path_lower(self): self._path_lower_value = None self._path_lower_present = False @property def permissions(self): """ The sharing permissions that requesting user has on this file. This corresponds to the entries given in ``GetFileMetadataBatchArg.actions`` or ``GetFileMetadataArg.actions``. :rtype: list of [FilePermission] """ if self._permissions_present: return self._permissions_value else: return None @permissions.setter def permissions(self, val): if val is None: del self.permissions return val = self._permissions_validator.validate(val) self._permissions_value = val self._permissions_present = True @permissions.deleter def permissions(self): self._permissions_value = None self._permissions_present = False @property def policy(self): """ Policies governing this shared file. :rtype: FolderPolicy """ if self._policy_present: return self._policy_value else: raise AttributeError("missing required field 'policy'") @policy.setter def policy(self, val): self._policy_validator.validate_type_only(val) self._policy_value = val self._policy_present = True @policy.deleter def policy(self): self._policy_value = None self._policy_present = False @property def preview_url(self): """ URL for displaying a web preview of the shared file. :rtype: str """ if self._preview_url_present: return self._preview_url_value else: raise AttributeError("missing required field 'preview_url'") @preview_url.setter def preview_url(self, val): val = self._preview_url_validator.validate(val) self._preview_url_value = val self._preview_url_present = True @preview_url.deleter def preview_url(self): self._preview_url_value = None self._preview_url_present = False @property def time_invited(self): """ Timestamp indicating when the current user was invited to this shared file. If the user was not invited to the shared file, the timestamp will indicate when the user was invited to the parent shared folder. This value may be absent. :rtype: datetime.datetime """ if self._time_invited_present: return self._time_invited_value else: return None @time_invited.setter def time_invited(self, val): if val is None: del self.time_invited return val = self._time_invited_validator.validate(val) self._time_invited_value = val self._time_invited_present = True @time_invited.deleter def time_invited(self): self._time_invited_value = None self._time_invited_present = False def __repr__(self): return 'SharedFileMetadata(id={!r}, name={!r}, policy={!r}, preview_url={!r}, access_type={!r}, expected_link_metadata={!r}, link_metadata={!r}, owner_display_names={!r}, owner_team={!r}, parent_shared_folder_id={!r}, path_display={!r}, path_lower={!r}, permissions={!r}, time_invited={!r})'.format( self._id_value, self._name_value, self._policy_value, self._preview_url_value, self._access_type_value, self._expected_link_metadata_value, self._link_metadata_value, self._owner_display_names_value, self._owner_team_value, self._parent_shared_folder_id_value, self._path_display_value, self._path_lower_value, self._permissions_value, self._time_invited_value, ) SharedFileMetadata_validator = bv.Struct(SharedFileMetadata) class SharedFolderAccessError(bb.Union): """ There is an error accessing the shared folder. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_id: This shared folder ID is invalid. :ivar not_a_member: The user is not a member of the shared folder thus cannot access it. :ivar email_unverified: The current user's e-mail address is unverified. :ivar unmounted: The shared folder is unmounted. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_id = None # Attribute is overwritten below the class definition not_a_member = None # Attribute is overwritten below the class definition email_unverified = None # Attribute is overwritten below the class definition unmounted = None # Attribute is overwritten below the class definition other = None def is_invalid_id(self): """ Check if the union tag is ``invalid_id``. :rtype: bool """ return self._tag == 'invalid_id' def is_not_a_member(self): """ Check if the union tag is ``not_a_member``. :rtype: bool """ return self._tag == 'not_a_member' def is_email_unverified(self): """ Check if the union tag is ``email_unverified``. :rtype: bool """ return self._tag == 'email_unverified' def is_unmounted(self): """ Check if the union tag is ``unmounted``. :rtype: bool """ return self._tag == 'unmounted' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharedFolderAccessError(%r, %r)' % (self._tag, self._value) SharedFolderAccessError_validator = bv.Union(SharedFolderAccessError) class SharedFolderMemberError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_dropbox_id: The target dropbox_id is invalid. :ivar not_a_member: The target dropbox_id is not a member of the shared folder. :ivar MemberAccessLevelResult no_explicit_access: The target member only has inherited access to the shared folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_dropbox_id = None # Attribute is overwritten below the class definition not_a_member = None # Attribute is overwritten below the class definition other = None @classmethod def no_explicit_access(cls, val): """ Create an instance of this class set to the ``no_explicit_access`` tag with value ``val``. :param MemberAccessLevelResult val: :rtype: SharedFolderMemberError """ return cls('no_explicit_access', val) def is_invalid_dropbox_id(self): """ Check if the union tag is ``invalid_dropbox_id``. :rtype: bool """ return self._tag == 'invalid_dropbox_id' def is_not_a_member(self): """ Check if the union tag is ``not_a_member``. :rtype: bool """ return self._tag == 'not_a_member' def is_no_explicit_access(self): """ Check if the union tag is ``no_explicit_access``. :rtype: bool """ return self._tag == 'no_explicit_access' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_no_explicit_access(self): """ The target member only has inherited access to the shared folder. Only call this if :meth:`is_no_explicit_access` is true. :rtype: MemberAccessLevelResult """ if not self.is_no_explicit_access(): raise AttributeError("tag 'no_explicit_access' not set") return self._value def __repr__(self): return 'SharedFolderMemberError(%r, %r)' % (self._tag, self._value) SharedFolderMemberError_validator = bv.Union(SharedFolderMemberError) class SharedFolderMembers(object): """ Shared folder user and group membership. :ivar users: The list of user members of the shared folder. :ivar groups: The list of group members of the shared folder. :ivar invitees: The list of invitees to the shared folder. :ivar cursor: Present if there are additional shared folder members that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members_continue` to list additional members. """ __slots__ = [ '_users_value', '_users_present', '_groups_value', '_groups_present', '_invitees_value', '_invitees_present', '_cursor_value', '_cursor_present', ] _has_required_fields = True def __init__(self, users=None, groups=None, invitees=None, cursor=None): self._users_value = None self._users_present = False self._groups_value = None self._groups_present = False self._invitees_value = None self._invitees_present = False self._cursor_value = None self._cursor_present = False if users is not None: self.users = users if groups is not None: self.groups = groups if invitees is not None: self.invitees = invitees if cursor is not None: self.cursor = cursor @property def users(self): """ The list of user members of the shared folder. :rtype: list of [UserMembershipInfo] """ if self._users_present: return self._users_value else: raise AttributeError("missing required field 'users'") @users.setter def users(self, val): val = self._users_validator.validate(val) self._users_value = val self._users_present = True @users.deleter def users(self): self._users_value = None self._users_present = False @property def groups(self): """ The list of group members of the shared folder. :rtype: list of [GroupMembershipInfo] """ if self._groups_present: return self._groups_value else: raise AttributeError("missing required field 'groups'") @groups.setter def groups(self, val): val = self._groups_validator.validate(val) self._groups_value = val self._groups_present = True @groups.deleter def groups(self): self._groups_value = None self._groups_present = False @property def invitees(self): """ The list of invitees to the shared folder. :rtype: list of [InviteeMembershipInfo] """ if self._invitees_present: return self._invitees_value else: raise AttributeError("missing required field 'invitees'") @invitees.setter def invitees(self, val): val = self._invitees_validator.validate(val) self._invitees_value = val self._invitees_present = True @invitees.deleter def invitees(self): self._invitees_value = None self._invitees_present = False @property def cursor(self): """ Present if there are additional shared folder members that have not been returned yet. Pass the cursor into :meth:`dropbox.dropbox.Dropbox.sharing_list_folder_members_continue` to list additional members. :rtype: str """ if self._cursor_present: return self._cursor_value else: return None @cursor.setter def cursor(self, val): if val is None: del self.cursor return val = self._cursor_validator.validate(val) self._cursor_value = val self._cursor_present = True @cursor.deleter def cursor(self): self._cursor_value = None self._cursor_present = False def __repr__(self): return 'SharedFolderMembers(users={!r}, groups={!r}, invitees={!r}, cursor={!r})'.format( self._users_value, self._groups_value, self._invitees_value, self._cursor_value, ) SharedFolderMembers_validator = bv.Struct(SharedFolderMembers) class SharedFolderMetadataBase(object): """ Properties of the shared folder. :ivar access_type: The current user's access level for this shared folder. :ivar is_inside_team_folder: Whether this folder is inside of a team folder. :ivar is_team_folder: Whether this folder is a `team folder `_. :ivar owner_display_names: The display names of the users that own the folder. If the folder is part of a team folder, the display names of the team admins are also included. Absent if the owner display names cannot be fetched. :ivar owner_team: The team that owns the folder. This field is not present if the folder is not owned by a team. :ivar parent_shared_folder_id: The ID of the parent shared folder. This field is present only if the folder is contained within another shared folder. :ivar path_lower: The lower-cased full path of this shared folder. Absent for unmounted folders. """ __slots__ = [ '_access_type_value', '_access_type_present', '_is_inside_team_folder_value', '_is_inside_team_folder_present', '_is_team_folder_value', '_is_team_folder_present', '_owner_display_names_value', '_owner_display_names_present', '_owner_team_value', '_owner_team_present', '_parent_shared_folder_id_value', '_parent_shared_folder_id_present', '_path_lower_value', '_path_lower_present', ] _has_required_fields = True def __init__(self, access_type=None, is_inside_team_folder=None, is_team_folder=None, owner_display_names=None, owner_team=None, parent_shared_folder_id=None, path_lower=None): self._access_type_value = None self._access_type_present = False self._is_inside_team_folder_value = None self._is_inside_team_folder_present = False self._is_team_folder_value = None self._is_team_folder_present = False self._owner_display_names_value = None self._owner_display_names_present = False self._owner_team_value = None self._owner_team_present = False self._parent_shared_folder_id_value = None self._parent_shared_folder_id_present = False self._path_lower_value = None self._path_lower_present = False if access_type is not None: self.access_type = access_type if is_inside_team_folder is not None: self.is_inside_team_folder = is_inside_team_folder if is_team_folder is not None: self.is_team_folder = is_team_folder if owner_display_names is not None: self.owner_display_names = owner_display_names if owner_team is not None: self.owner_team = owner_team if parent_shared_folder_id is not None: self.parent_shared_folder_id = parent_shared_folder_id if path_lower is not None: self.path_lower = path_lower @property def access_type(self): """ The current user's access level for this shared folder. :rtype: AccessLevel """ if self._access_type_present: return self._access_type_value else: raise AttributeError("missing required field 'access_type'") @access_type.setter def access_type(self, val): self._access_type_validator.validate_type_only(val) self._access_type_value = val self._access_type_present = True @access_type.deleter def access_type(self): self._access_type_value = None self._access_type_present = False @property def is_inside_team_folder(self): """ Whether this folder is inside of a team folder. :rtype: bool """ if self._is_inside_team_folder_present: return self._is_inside_team_folder_value else: raise AttributeError("missing required field 'is_inside_team_folder'") @is_inside_team_folder.setter def is_inside_team_folder(self, val): val = self._is_inside_team_folder_validator.validate(val) self._is_inside_team_folder_value = val self._is_inside_team_folder_present = True @is_inside_team_folder.deleter def is_inside_team_folder(self): self._is_inside_team_folder_value = None self._is_inside_team_folder_present = False @property def is_team_folder(self): """ Whether this folder is a `team folder `_. :rtype: bool """ if self._is_team_folder_present: return self._is_team_folder_value else: raise AttributeError("missing required field 'is_team_folder'") @is_team_folder.setter def is_team_folder(self, val): val = self._is_team_folder_validator.validate(val) self._is_team_folder_value = val self._is_team_folder_present = True @is_team_folder.deleter def is_team_folder(self): self._is_team_folder_value = None self._is_team_folder_present = False @property def owner_display_names(self): """ The display names of the users that own the folder. If the folder is part of a team folder, the display names of the team admins are also included. Absent if the owner display names cannot be fetched. :rtype: list of [str] """ if self._owner_display_names_present: return self._owner_display_names_value else: return None @owner_display_names.setter def owner_display_names(self, val): if val is None: del self.owner_display_names return val = self._owner_display_names_validator.validate(val) self._owner_display_names_value = val self._owner_display_names_present = True @owner_display_names.deleter def owner_display_names(self): self._owner_display_names_value = None self._owner_display_names_present = False @property def owner_team(self): """ The team that owns the folder. This field is not present if the folder is not owned by a team. :rtype: users.Team_validator """ if self._owner_team_present: return self._owner_team_value else: return None @owner_team.setter def owner_team(self, val): if val is None: del self.owner_team return self._owner_team_validator.validate_type_only(val) self._owner_team_value = val self._owner_team_present = True @owner_team.deleter def owner_team(self): self._owner_team_value = None self._owner_team_present = False @property def parent_shared_folder_id(self): """ The ID of the parent shared folder. This field is present only if the folder is contained within another shared folder. :rtype: str """ if self._parent_shared_folder_id_present: return self._parent_shared_folder_id_value else: return None @parent_shared_folder_id.setter def parent_shared_folder_id(self, val): if val is None: del self.parent_shared_folder_id return val = self._parent_shared_folder_id_validator.validate(val) self._parent_shared_folder_id_value = val self._parent_shared_folder_id_present = True @parent_shared_folder_id.deleter def parent_shared_folder_id(self): self._parent_shared_folder_id_value = None self._parent_shared_folder_id_present = False @property def path_lower(self): """ The lower-cased full path of this shared folder. Absent for unmounted folders. :rtype: str """ if self._path_lower_present: return self._path_lower_value else: return None @path_lower.setter def path_lower(self, val): if val is None: del self.path_lower return val = self._path_lower_validator.validate(val) self._path_lower_value = val self._path_lower_present = True @path_lower.deleter def path_lower(self): self._path_lower_value = None self._path_lower_present = False def __repr__(self): return 'SharedFolderMetadataBase(access_type={!r}, is_inside_team_folder={!r}, is_team_folder={!r}, owner_display_names={!r}, owner_team={!r}, parent_shared_folder_id={!r}, path_lower={!r})'.format( self._access_type_value, self._is_inside_team_folder_value, self._is_team_folder_value, self._owner_display_names_value, self._owner_team_value, self._parent_shared_folder_id_value, self._path_lower_value, ) SharedFolderMetadataBase_validator = bv.Struct(SharedFolderMetadataBase) class SharedFolderMetadata(SharedFolderMetadataBase): """ The metadata which includes basic information about the shared folder. :ivar link_metadata: The metadata of the shared content link to this shared folder. Absent if there is no link on the folder. This is for an unreleased feature so it may not be returned yet. :ivar name: The name of the this shared folder. :ivar permissions: Actions the current user may perform on the folder and its contents. The set of permissions corresponds to the FolderActions in the request. :ivar policy: Policies governing this shared folder. :ivar preview_url: URL for displaying a web preview of the shared folder. :ivar shared_folder_id: The ID of the shared folder. :ivar time_invited: Timestamp indicating when the current user was invited to this shared folder. """ __slots__ = [ '_link_metadata_value', '_link_metadata_present', '_name_value', '_name_present', '_permissions_value', '_permissions_present', '_policy_value', '_policy_present', '_preview_url_value', '_preview_url_present', '_shared_folder_id_value', '_shared_folder_id_present', '_time_invited_value', '_time_invited_present', ] _has_required_fields = True def __init__(self, access_type=None, is_inside_team_folder=None, is_team_folder=None, name=None, policy=None, preview_url=None, shared_folder_id=None, time_invited=None, owner_display_names=None, owner_team=None, parent_shared_folder_id=None, path_lower=None, link_metadata=None, permissions=None): super(SharedFolderMetadata, self).__init__(access_type, is_inside_team_folder, is_team_folder, owner_display_names, owner_team, parent_shared_folder_id, path_lower) self._link_metadata_value = None self._link_metadata_present = False self._name_value = None self._name_present = False self._permissions_value = None self._permissions_present = False self._policy_value = None self._policy_present = False self._preview_url_value = None self._preview_url_present = False self._shared_folder_id_value = None self._shared_folder_id_present = False self._time_invited_value = None self._time_invited_present = False if link_metadata is not None: self.link_metadata = link_metadata if name is not None: self.name = name if permissions is not None: self.permissions = permissions if policy is not None: self.policy = policy if preview_url is not None: self.preview_url = preview_url if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if time_invited is not None: self.time_invited = time_invited @property def link_metadata(self): """ The metadata of the shared content link to this shared folder. Absent if there is no link on the folder. This is for an unreleased feature so it may not be returned yet. :rtype: SharedContentLinkMetadata """ if self._link_metadata_present: return self._link_metadata_value else: return None @link_metadata.setter def link_metadata(self, val): if val is None: del self.link_metadata return self._link_metadata_validator.validate_type_only(val) self._link_metadata_value = val self._link_metadata_present = True @link_metadata.deleter def link_metadata(self): self._link_metadata_value = None self._link_metadata_present = False @property def name(self): """ The name of the this shared folder. :rtype: str """ if self._name_present: return self._name_value else: raise AttributeError("missing required field 'name'") @name.setter def name(self, val): val = self._name_validator.validate(val) self._name_value = val self._name_present = True @name.deleter def name(self): self._name_value = None self._name_present = False @property def permissions(self): """ Actions the current user may perform on the folder and its contents. The set of permissions corresponds to the FolderActions in the request. :rtype: list of [FolderPermission] """ if self._permissions_present: return self._permissions_value else: return None @permissions.setter def permissions(self, val): if val is None: del self.permissions return val = self._permissions_validator.validate(val) self._permissions_value = val self._permissions_present = True @permissions.deleter def permissions(self): self._permissions_value = None self._permissions_present = False @property def policy(self): """ Policies governing this shared folder. :rtype: FolderPolicy """ if self._policy_present: return self._policy_value else: raise AttributeError("missing required field 'policy'") @policy.setter def policy(self, val): self._policy_validator.validate_type_only(val) self._policy_value = val self._policy_present = True @policy.deleter def policy(self): self._policy_value = None self._policy_present = False @property def preview_url(self): """ URL for displaying a web preview of the shared folder. :rtype: str """ if self._preview_url_present: return self._preview_url_value else: raise AttributeError("missing required field 'preview_url'") @preview_url.setter def preview_url(self, val): val = self._preview_url_validator.validate(val) self._preview_url_value = val self._preview_url_present = True @preview_url.deleter def preview_url(self): self._preview_url_value = None self._preview_url_present = False @property def shared_folder_id(self): """ The ID of the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def time_invited(self): """ Timestamp indicating when the current user was invited to this shared folder. :rtype: datetime.datetime """ if self._time_invited_present: return self._time_invited_value else: raise AttributeError("missing required field 'time_invited'") @time_invited.setter def time_invited(self, val): val = self._time_invited_validator.validate(val) self._time_invited_value = val self._time_invited_present = True @time_invited.deleter def time_invited(self): self._time_invited_value = None self._time_invited_present = False def __repr__(self): return 'SharedFolderMetadata(access_type={!r}, is_inside_team_folder={!r}, is_team_folder={!r}, name={!r}, policy={!r}, preview_url={!r}, shared_folder_id={!r}, time_invited={!r}, owner_display_names={!r}, owner_team={!r}, parent_shared_folder_id={!r}, path_lower={!r}, link_metadata={!r}, permissions={!r})'.format( self._access_type_value, self._is_inside_team_folder_value, self._is_team_folder_value, self._name_value, self._policy_value, self._preview_url_value, self._shared_folder_id_value, self._time_invited_value, self._owner_display_names_value, self._owner_team_value, self._parent_shared_folder_id_value, self._path_lower_value, self._link_metadata_value, self._permissions_value, ) SharedFolderMetadata_validator = bv.Struct(SharedFolderMetadata) class SharedLinkAccessFailureReason(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar login_required: User is not logged in. :ivar email_verify_required: User's email is not verified. :ivar password_required: The link is password protected. :ivar team_only: Access is allowed for team members only. :ivar owner_only: Access is allowed for the shared link's owner only. """ _catch_all = 'other' # Attribute is overwritten below the class definition login_required = None # Attribute is overwritten below the class definition email_verify_required = None # Attribute is overwritten below the class definition password_required = None # Attribute is overwritten below the class definition team_only = None # Attribute is overwritten below the class definition owner_only = None # Attribute is overwritten below the class definition other = None def is_login_required(self): """ Check if the union tag is ``login_required``. :rtype: bool """ return self._tag == 'login_required' def is_email_verify_required(self): """ Check if the union tag is ``email_verify_required``. :rtype: bool """ return self._tag == 'email_verify_required' def is_password_required(self): """ Check if the union tag is ``password_required``. :rtype: bool """ return self._tag == 'password_required' def is_team_only(self): """ Check if the union tag is ``team_only``. :rtype: bool """ return self._tag == 'team_only' def is_owner_only(self): """ Check if the union tag is ``owner_only``. :rtype: bool """ return self._tag == 'owner_only' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharedLinkAccessFailureReason(%r, %r)' % (self._tag, self._value) SharedLinkAccessFailureReason_validator = bv.Union(SharedLinkAccessFailureReason) class SharedLinkPolicy(bb.Union): """ Who can view shared links in this folder. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar anyone: Links can be shared with anyone. :ivar team: Links can be shared with anyone on the same team as the owner. :ivar members: Links can only be shared among members of the shared folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition anyone = None # Attribute is overwritten below the class definition team = None # Attribute is overwritten below the class definition members = None # Attribute is overwritten below the class definition other = None def is_anyone(self): """ Check if the union tag is ``anyone``. :rtype: bool """ return self._tag == 'anyone' def is_team(self): """ Check if the union tag is ``team``. :rtype: bool """ return self._tag == 'team' def is_members(self): """ Check if the union tag is ``members``. :rtype: bool """ return self._tag == 'members' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharedLinkPolicy(%r, %r)' % (self._tag, self._value) SharedLinkPolicy_validator = bv.Union(SharedLinkPolicy) class SharedLinkSettings(object): """ :ivar requested_visibility: The requested access for this shared link. :ivar link_password: If ``requested_visibility`` is ``RequestedVisibility.password`` this is needed to specify the password to access the link. :ivar expires: Expiration time of the shared link. By default the link won't expire. """ __slots__ = [ '_requested_visibility_value', '_requested_visibility_present', '_link_password_value', '_link_password_present', '_expires_value', '_expires_present', ] _has_required_fields = False def __init__(self, requested_visibility=None, link_password=None, expires=None): self._requested_visibility_value = None self._requested_visibility_present = False self._link_password_value = None self._link_password_present = False self._expires_value = None self._expires_present = False if requested_visibility is not None: self.requested_visibility = requested_visibility if link_password is not None: self.link_password = link_password if expires is not None: self.expires = expires @property def requested_visibility(self): """ The requested access for this shared link. :rtype: RequestedVisibility """ if self._requested_visibility_present: return self._requested_visibility_value else: return None @requested_visibility.setter def requested_visibility(self, val): if val is None: del self.requested_visibility return self._requested_visibility_validator.validate_type_only(val) self._requested_visibility_value = val self._requested_visibility_present = True @requested_visibility.deleter def requested_visibility(self): self._requested_visibility_value = None self._requested_visibility_present = False @property def link_password(self): """ If ``requested_visibility`` is ``RequestedVisibility.password`` this is needed to specify the password to access the link. :rtype: str """ if self._link_password_present: return self._link_password_value else: return None @link_password.setter def link_password(self, val): if val is None: del self.link_password return val = self._link_password_validator.validate(val) self._link_password_value = val self._link_password_present = True @link_password.deleter def link_password(self): self._link_password_value = None self._link_password_present = False @property def expires(self): """ Expiration time of the shared link. By default the link won't expire. :rtype: datetime.datetime """ if self._expires_present: return self._expires_value else: return None @expires.setter def expires(self, val): if val is None: del self.expires return val = self._expires_validator.validate(val) self._expires_value = val self._expires_present = True @expires.deleter def expires(self): self._expires_value = None self._expires_present = False def __repr__(self): return 'SharedLinkSettings(requested_visibility={!r}, link_password={!r}, expires={!r})'.format( self._requested_visibility_value, self._link_password_value, self._expires_value, ) SharedLinkSettings_validator = bv.Struct(SharedLinkSettings) class SharedLinkSettingsError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_settings: The given settings are invalid (for example, all attributes of the :class:`SharedLinkSettings` are empty, the requested visibility is ``RequestedVisibility.password`` but the ``SharedLinkSettings.link_password`` is missing, ``SharedLinkSettings.expires`` is set to the past, etc.). :ivar not_authorized: User is not allowed to modify the settings of this link. Note that basic users can only set ``RequestedVisibility.public`` as the ``SharedLinkSettings.requested_visibility`` and cannot set ``SharedLinkSettings.expires``. """ _catch_all = None # Attribute is overwritten below the class definition invalid_settings = None # Attribute is overwritten below the class definition not_authorized = None def is_invalid_settings(self): """ Check if the union tag is ``invalid_settings``. :rtype: bool """ return self._tag == 'invalid_settings' def is_not_authorized(self): """ Check if the union tag is ``not_authorized``. :rtype: bool """ return self._tag == 'not_authorized' def __repr__(self): return 'SharedLinkSettingsError(%r, %r)' % (self._tag, self._value) SharedLinkSettingsError_validator = bv.Union(SharedLinkSettingsError) class SharingFileAccessError(bb.Union): """ User could not access this file. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar no_permission: Current user does not have sufficient privileges to perform the desired action. :ivar invalid_file: File specified was not found. :ivar is_folder: A folder can't be shared this way. Use folder sharing or a shared link instead. :ivar inside_public_folder: A file inside a public folder can't be shared this way. Use a public link instead. :ivar inside_osx_package: A Mac OS X package can't be shared this way. Use a shared link instead. """ _catch_all = 'other' # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition invalid_file = None # Attribute is overwritten below the class definition is_folder = None # Attribute is overwritten below the class definition inside_public_folder = None # Attribute is overwritten below the class definition inside_osx_package = None # Attribute is overwritten below the class definition other = None def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_invalid_file(self): """ Check if the union tag is ``invalid_file``. :rtype: bool """ return self._tag == 'invalid_file' def is_is_folder(self): """ Check if the union tag is ``is_folder``. :rtype: bool """ return self._tag == 'is_folder' def is_inside_public_folder(self): """ Check if the union tag is ``inside_public_folder``. :rtype: bool """ return self._tag == 'inside_public_folder' def is_inside_osx_package(self): """ Check if the union tag is ``inside_osx_package``. :rtype: bool """ return self._tag == 'inside_osx_package' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharingFileAccessError(%r, %r)' % (self._tag, self._value) SharingFileAccessError_validator = bv.Union(SharingFileAccessError) class SharingUserError(bb.Union): """ User account had a problem preventing this action. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar email_unverified: The current user must verify the account e-mail address before performing this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition email_unverified = None # Attribute is overwritten below the class definition other = None def is_email_unverified(self): """ Check if the union tag is ``email_unverified``. :rtype: bool """ return self._tag == 'email_unverified' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'SharingUserError(%r, %r)' % (self._tag, self._value) SharingUserError_validator = bv.Union(SharingUserError) class TeamMemberInfo(object): """ Information about a team member. :ivar team_info: Information about the member's team. :ivar display_name: The display name of the user. :ivar member_id: ID of user as a member of a team. This field will only be present if the member is in the same team as current user. """ __slots__ = [ '_team_info_value', '_team_info_present', '_display_name_value', '_display_name_present', '_member_id_value', '_member_id_present', ] _has_required_fields = True def __init__(self, team_info=None, display_name=None, member_id=None): self._team_info_value = None self._team_info_present = False self._display_name_value = None self._display_name_present = False self._member_id_value = None self._member_id_present = False if team_info is not None: self.team_info = team_info if display_name is not None: self.display_name = display_name if member_id is not None: self.member_id = member_id @property def team_info(self): """ Information about the member's team. :rtype: users.Team_validator """ if self._team_info_present: return self._team_info_value else: raise AttributeError("missing required field 'team_info'") @team_info.setter def team_info(self, val): val = self._team_info_validator.validate(val) self._team_info_value = val self._team_info_present = True @team_info.deleter def team_info(self): self._team_info_value = None self._team_info_present = False @property def display_name(self): """ The display name of the user. :rtype: str """ if self._display_name_present: return self._display_name_value else: raise AttributeError("missing required field 'display_name'") @display_name.setter def display_name(self, val): val = self._display_name_validator.validate(val) self._display_name_value = val self._display_name_present = True @display_name.deleter def display_name(self): self._display_name_value = None self._display_name_present = False @property def member_id(self): """ ID of user as a member of a team. This field will only be present if the member is in the same team as current user. :rtype: str """ if self._member_id_present: return self._member_id_value else: return None @member_id.setter def member_id(self, val): if val is None: del self.member_id return val = self._member_id_validator.validate(val) self._member_id_value = val self._member_id_present = True @member_id.deleter def member_id(self): self._member_id_value = None self._member_id_present = False def __repr__(self): return 'TeamMemberInfo(team_info={!r}, display_name={!r}, member_id={!r})'.format( self._team_info_value, self._display_name_value, self._member_id_value, ) TeamMemberInfo_validator = bv.Struct(TeamMemberInfo) class TransferFolderArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar to_dropbox_id: A account or team member ID to transfer ownership to. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_to_dropbox_id_value', '_to_dropbox_id_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, to_dropbox_id=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._to_dropbox_id_value = None self._to_dropbox_id_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if to_dropbox_id is not None: self.to_dropbox_id = to_dropbox_id @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def to_dropbox_id(self): """ A account or team member ID to transfer ownership to. :rtype: str """ if self._to_dropbox_id_present: return self._to_dropbox_id_value else: raise AttributeError("missing required field 'to_dropbox_id'") @to_dropbox_id.setter def to_dropbox_id(self, val): val = self._to_dropbox_id_validator.validate(val) self._to_dropbox_id_value = val self._to_dropbox_id_present = True @to_dropbox_id.deleter def to_dropbox_id(self): self._to_dropbox_id_value = None self._to_dropbox_id_present = False def __repr__(self): return 'TransferFolderArg(shared_folder_id={!r}, to_dropbox_id={!r})'.format( self._shared_folder_id_value, self._to_dropbox_id_value, ) TransferFolderArg_validator = bv.Struct(TransferFolderArg) class TransferFolderError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar invalid_dropbox_id: ``TransferFolderArg.to_dropbox_id`` is invalid. :ivar new_owner_not_a_member: The new designated owner is not currently a member of the shared folder. :ivar new_owner_unmounted: The new designated owner has not added the folder to their Dropbox. :ivar new_owner_email_unverified: The new designated owner's e-mail address is unverified. :ivar team_folder: This action cannot be performed on a team shared folder. :ivar no_permission: The current user does not have permission to perform this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition invalid_dropbox_id = None # Attribute is overwritten below the class definition new_owner_not_a_member = None # Attribute is overwritten below the class definition new_owner_unmounted = None # Attribute is overwritten below the class definition new_owner_email_unverified = None # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: TransferFolderError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_invalid_dropbox_id(self): """ Check if the union tag is ``invalid_dropbox_id``. :rtype: bool """ return self._tag == 'invalid_dropbox_id' def is_new_owner_not_a_member(self): """ Check if the union tag is ``new_owner_not_a_member``. :rtype: bool """ return self._tag == 'new_owner_not_a_member' def is_new_owner_unmounted(self): """ Check if the union tag is ``new_owner_unmounted``. :rtype: bool """ return self._tag == 'new_owner_unmounted' def is_new_owner_email_unverified(self): """ Check if the union tag is ``new_owner_email_unverified``. :rtype: bool """ return self._tag == 'new_owner_email_unverified' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'TransferFolderError(%r, %r)' % (self._tag, self._value) TransferFolderError_validator = bv.Union(TransferFolderError) class UnmountFolderArg(object): """ :ivar shared_folder_id: The ID for the shared folder. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None): self._shared_folder_id_value = None self._shared_folder_id_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False def __repr__(self): return 'UnmountFolderArg(shared_folder_id={!r})'.format( self._shared_folder_id_value, ) UnmountFolderArg_validator = bv.Struct(UnmountFolderArg) class UnmountFolderError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar no_permission: The current user does not have permission to perform this action. :ivar not_unmountable: The shared folder can't be unmounted. One example where this can occur is when the shared folder's parent folder is also a shared folder that resides in the current user's Dropbox. """ _catch_all = 'other' # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition not_unmountable = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: UnmountFolderError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_not_unmountable(self): """ Check if the union tag is ``not_unmountable``. :rtype: bool """ return self._tag == 'not_unmountable' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'UnmountFolderError(%r, %r)' % (self._tag, self._value) UnmountFolderError_validator = bv.Union(UnmountFolderError) class UnshareFileArg(object): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_unshare_file`. :ivar file: The file to unshare. """ __slots__ = [ '_file_value', '_file_present', ] _has_required_fields = True def __init__(self, file=None): self._file_value = None self._file_present = False if file is not None: self.file = file @property def file(self): """ The file to unshare. :rtype: str """ if self._file_present: return self._file_value else: raise AttributeError("missing required field 'file'") @file.setter def file(self, val): val = self._file_validator.validate(val) self._file_value = val self._file_present = True @file.deleter def file(self): self._file_value = None self._file_present = False def __repr__(self): return 'UnshareFileArg(file={!r})'.format( self._file_value, ) UnshareFileArg_validator = bv.Struct(UnshareFileArg) class UnshareFileError(bb.Union): """ Error result for :meth:`dropbox.dropbox.Dropbox.sharing_unshare_file`. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. """ _catch_all = 'other' # Attribute is overwritten below the class definition other = None @classmethod def user_error(cls, val): """ Create an instance of this class set to the ``user_error`` tag with value ``val``. :param SharingUserError val: :rtype: UnshareFileError """ return cls('user_error', val) @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharingFileAccessError val: :rtype: UnshareFileError """ return cls('access_error', val) def is_user_error(self): """ Check if the union tag is ``user_error``. :rtype: bool """ return self._tag == 'user_error' def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_user_error(self): """ Only call this if :meth:`is_user_error` is true. :rtype: SharingUserError """ if not self.is_user_error(): raise AttributeError("tag 'user_error' not set") return self._value def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharingFileAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'UnshareFileError(%r, %r)' % (self._tag, self._value) UnshareFileError_validator = bv.Union(UnshareFileError) class UnshareFolderArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar leave_a_copy: If true, members of this shared folder will get a copy of this folder after it's unshared. Otherwise, it will be removed from their Dropbox. The current user, who is an owner, will always retain their copy. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_leave_a_copy_value', '_leave_a_copy_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, leave_a_copy=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._leave_a_copy_value = None self._leave_a_copy_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if leave_a_copy is not None: self.leave_a_copy = leave_a_copy @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def leave_a_copy(self): """ If true, members of this shared folder will get a copy of this folder after it's unshared. Otherwise, it will be removed from their Dropbox. The current user, who is an owner, will always retain their copy. :rtype: bool """ if self._leave_a_copy_present: return self._leave_a_copy_value else: return False @leave_a_copy.setter def leave_a_copy(self, val): val = self._leave_a_copy_validator.validate(val) self._leave_a_copy_value = val self._leave_a_copy_present = True @leave_a_copy.deleter def leave_a_copy(self): self._leave_a_copy_value = None self._leave_a_copy_present = False def __repr__(self): return 'UnshareFolderArg(shared_folder_id={!r}, leave_a_copy={!r})'.format( self._shared_folder_id_value, self._leave_a_copy_value, ) UnshareFolderArg_validator = bv.Struct(UnshareFolderArg) class UnshareFolderError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar team_folder: This action cannot be performed on a team shared folder. :ivar no_permission: The current user does not have permission to perform this action. :ivar too_many_files: This shared folder has too many files to be unshared. """ _catch_all = 'other' # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition too_many_files = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: UnshareFolderError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_too_many_files(self): """ Check if the union tag is ``too_many_files``. :rtype: bool """ return self._tag == 'too_many_files' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'UnshareFolderError(%r, %r)' % (self._tag, self._value) UnshareFolderError_validator = bv.Union(UnshareFolderError) class UpdateFileMemberArgs(ChangeFileMemberAccessArgs): """ Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_update_file_member`. """ __slots__ = [ ] _has_required_fields = True def __init__(self, file=None, member=None, access_level=None): super(UpdateFileMemberArgs, self).__init__(file, member, access_level) def __repr__(self): return 'UpdateFileMemberArgs(file={!r}, member={!r}, access_level={!r})'.format( self._file_value, self._member_value, self._access_level_value, ) UpdateFileMemberArgs_validator = bv.Struct(UpdateFileMemberArgs) class UpdateFolderMemberArg(object): """ :ivar shared_folder_id: The ID for the shared folder. :ivar member: The member of the shared folder to update. Only the ``MemberSelector.dropbox_id`` may be set at this time. :ivar access_level: The new access level for ``member``. ``AccessLevel.owner`` is disallowed. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_member_value', '_member_present', '_access_level_value', '_access_level_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, member=None, access_level=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._member_value = None self._member_present = False self._access_level_value = None self._access_level_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if member is not None: self.member = member if access_level is not None: self.access_level = access_level @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def member(self): """ The member of the shared folder to update. Only the ``MemberSelector.dropbox_id`` may be set at this time. :rtype: MemberSelector """ if self._member_present: return self._member_value else: raise AttributeError("missing required field 'member'") @member.setter def member(self, val): self._member_validator.validate_type_only(val) self._member_value = val self._member_present = True @member.deleter def member(self): self._member_value = None self._member_present = False @property def access_level(self): """ The new access level for ``member``. ``AccessLevel.owner`` is disallowed. :rtype: AccessLevel """ if self._access_level_present: return self._access_level_value else: raise AttributeError("missing required field 'access_level'") @access_level.setter def access_level(self, val): self._access_level_validator.validate_type_only(val) self._access_level_value = val self._access_level_present = True @access_level.deleter def access_level(self): self._access_level_value = None self._access_level_present = False def __repr__(self): return 'UpdateFolderMemberArg(shared_folder_id={!r}, member={!r}, access_level={!r})'.format( self._shared_folder_id_value, self._member_value, self._access_level_value, ) UpdateFolderMemberArg_validator = bv.Struct(UpdateFolderMemberArg) class UpdateFolderMemberError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar AddFolderMemberError no_explicit_access: If updating the access type required the member to be added to the shared folder and there was an error when adding the member. :ivar insufficient_plan: The current user's account doesn't support this action. An example of this is when downgrading a member from editor to viewer. This action can only be performed by users that have upgraded to a Pro or Business plan. :ivar no_permission: The current user does not have permission to perform this action. """ _catch_all = 'other' # Attribute is overwritten below the class definition insufficient_plan = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: UpdateFolderMemberError """ return cls('access_error', val) @classmethod def member_error(cls, val): """ Create an instance of this class set to the ``member_error`` tag with value ``val``. :param SharedFolderMemberError val: :rtype: UpdateFolderMemberError """ return cls('member_error', val) @classmethod def no_explicit_access(cls, val): """ Create an instance of this class set to the ``no_explicit_access`` tag with value ``val``. :param AddFolderMemberError val: :rtype: UpdateFolderMemberError """ return cls('no_explicit_access', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_member_error(self): """ Check if the union tag is ``member_error``. :rtype: bool """ return self._tag == 'member_error' def is_no_explicit_access(self): """ Check if the union tag is ``no_explicit_access``. :rtype: bool """ return self._tag == 'no_explicit_access' def is_insufficient_plan(self): """ Check if the union tag is ``insufficient_plan``. :rtype: bool """ return self._tag == 'insufficient_plan' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def get_member_error(self): """ Only call this if :meth:`is_member_error` is true. :rtype: SharedFolderMemberError """ if not self.is_member_error(): raise AttributeError("tag 'member_error' not set") return self._value def get_no_explicit_access(self): """ If updating the access type required the member to be added to the shared folder and there was an error when adding the member. Only call this if :meth:`is_no_explicit_access` is true. :rtype: AddFolderMemberError """ if not self.is_no_explicit_access(): raise AttributeError("tag 'no_explicit_access' not set") return self._value def __repr__(self): return 'UpdateFolderMemberError(%r, %r)' % (self._tag, self._value) UpdateFolderMemberError_validator = bv.Union(UpdateFolderMemberError) class UpdateFolderPolicyArg(object): """ If any of the policies are unset, then they retain their current setting. :ivar shared_folder_id: The ID for the shared folder. :ivar member_policy: Who can be a member of this shared folder. Only applicable if the current user is on a team. :ivar acl_update_policy: Who can add and remove members of this shared folder. :ivar viewer_info_policy: Who can enable/disable viewer info for this shared folder. :ivar shared_link_policy: The policy to apply to shared links created for content inside this shared folder. The current user must be on a team to set this policy to ``SharedLinkPolicy.members``. :ivar link_settings: Settings on the link for this folder. :ivar actions: A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. """ __slots__ = [ '_shared_folder_id_value', '_shared_folder_id_present', '_member_policy_value', '_member_policy_present', '_acl_update_policy_value', '_acl_update_policy_present', '_viewer_info_policy_value', '_viewer_info_policy_present', '_shared_link_policy_value', '_shared_link_policy_present', '_link_settings_value', '_link_settings_present', '_actions_value', '_actions_present', ] _has_required_fields = True def __init__(self, shared_folder_id=None, member_policy=None, acl_update_policy=None, viewer_info_policy=None, shared_link_policy=None, link_settings=None, actions=None): self._shared_folder_id_value = None self._shared_folder_id_present = False self._member_policy_value = None self._member_policy_present = False self._acl_update_policy_value = None self._acl_update_policy_present = False self._viewer_info_policy_value = None self._viewer_info_policy_present = False self._shared_link_policy_value = None self._shared_link_policy_present = False self._link_settings_value = None self._link_settings_present = False self._actions_value = None self._actions_present = False if shared_folder_id is not None: self.shared_folder_id = shared_folder_id if member_policy is not None: self.member_policy = member_policy if acl_update_policy is not None: self.acl_update_policy = acl_update_policy if viewer_info_policy is not None: self.viewer_info_policy = viewer_info_policy if shared_link_policy is not None: self.shared_link_policy = shared_link_policy if link_settings is not None: self.link_settings = link_settings if actions is not None: self.actions = actions @property def shared_folder_id(self): """ The ID for the shared folder. :rtype: str """ if self._shared_folder_id_present: return self._shared_folder_id_value else: raise AttributeError("missing required field 'shared_folder_id'") @shared_folder_id.setter def shared_folder_id(self, val): val = self._shared_folder_id_validator.validate(val) self._shared_folder_id_value = val self._shared_folder_id_present = True @shared_folder_id.deleter def shared_folder_id(self): self._shared_folder_id_value = None self._shared_folder_id_present = False @property def member_policy(self): """ Who can be a member of this shared folder. Only applicable if the current user is on a team. :rtype: MemberPolicy """ if self._member_policy_present: return self._member_policy_value else: return None @member_policy.setter def member_policy(self, val): if val is None: del self.member_policy return self._member_policy_validator.validate_type_only(val) self._member_policy_value = val self._member_policy_present = True @member_policy.deleter def member_policy(self): self._member_policy_value = None self._member_policy_present = False @property def acl_update_policy(self): """ Who can add and remove members of this shared folder. :rtype: AclUpdatePolicy """ if self._acl_update_policy_present: return self._acl_update_policy_value else: return None @acl_update_policy.setter def acl_update_policy(self, val): if val is None: del self.acl_update_policy return self._acl_update_policy_validator.validate_type_only(val) self._acl_update_policy_value = val self._acl_update_policy_present = True @acl_update_policy.deleter def acl_update_policy(self): self._acl_update_policy_value = None self._acl_update_policy_present = False @property def viewer_info_policy(self): """ Who can enable/disable viewer info for this shared folder. :rtype: ViewerInfoPolicy """ if self._viewer_info_policy_present: return self._viewer_info_policy_value else: return None @viewer_info_policy.setter def viewer_info_policy(self, val): if val is None: del self.viewer_info_policy return self._viewer_info_policy_validator.validate_type_only(val) self._viewer_info_policy_value = val self._viewer_info_policy_present = True @viewer_info_policy.deleter def viewer_info_policy(self): self._viewer_info_policy_value = None self._viewer_info_policy_present = False @property def shared_link_policy(self): """ The policy to apply to shared links created for content inside this shared folder. The current user must be on a team to set this policy to ``SharedLinkPolicy.members``. :rtype: SharedLinkPolicy """ if self._shared_link_policy_present: return self._shared_link_policy_value else: return None @shared_link_policy.setter def shared_link_policy(self, val): if val is None: del self.shared_link_policy return self._shared_link_policy_validator.validate_type_only(val) self._shared_link_policy_value = val self._shared_link_policy_present = True @shared_link_policy.deleter def shared_link_policy(self): self._shared_link_policy_value = None self._shared_link_policy_present = False @property def link_settings(self): """ Settings on the link for this folder. :rtype: LinkSettings """ if self._link_settings_present: return self._link_settings_value else: return None @link_settings.setter def link_settings(self, val): if val is None: del self.link_settings return self._link_settings_validator.validate_type_only(val) self._link_settings_value = val self._link_settings_present = True @link_settings.deleter def link_settings(self): self._link_settings_value = None self._link_settings_present = False @property def actions(self): """ A list of `FolderAction`s corresponding to `FolderPermission`s that should appear in the response's ``SharedFolderMetadata.permissions`` field describing the actions the authenticated user can perform on the folder. :rtype: list of [FolderAction] """ if self._actions_present: return self._actions_value else: return None @actions.setter def actions(self, val): if val is None: del self.actions return val = self._actions_validator.validate(val) self._actions_value = val self._actions_present = True @actions.deleter def actions(self): self._actions_value = None self._actions_present = False def __repr__(self): return 'UpdateFolderPolicyArg(shared_folder_id={!r}, member_policy={!r}, acl_update_policy={!r}, viewer_info_policy={!r}, shared_link_policy={!r}, link_settings={!r}, actions={!r})'.format( self._shared_folder_id_value, self._member_policy_value, self._acl_update_policy_value, self._viewer_info_policy_value, self._shared_link_policy_value, self._link_settings_value, self._actions_value, ) UpdateFolderPolicyArg_validator = bv.Struct(UpdateFolderPolicyArg) class UpdateFolderPolicyError(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar not_on_team: ``UpdateFolderPolicyArg.member_policy`` was set even though user is not on a team. :ivar team_policy_disallows_member_policy: Team policy is more restrictive than ``ShareFolderArg.member_policy``. :ivar disallowed_shared_link_policy: The current account is not allowed to select the specified ``ShareFolderArg.shared_link_policy``. :ivar no_permission: The current user does not have permission to perform this action. :ivar team_folder: This action cannot be performed on a team shared folder. """ _catch_all = 'other' # Attribute is overwritten below the class definition not_on_team = None # Attribute is overwritten below the class definition team_policy_disallows_member_policy = None # Attribute is overwritten below the class definition disallowed_shared_link_policy = None # Attribute is overwritten below the class definition no_permission = None # Attribute is overwritten below the class definition team_folder = None # Attribute is overwritten below the class definition other = None @classmethod def access_error(cls, val): """ Create an instance of this class set to the ``access_error`` tag with value ``val``. :param SharedFolderAccessError val: :rtype: UpdateFolderPolicyError """ return cls('access_error', val) def is_access_error(self): """ Check if the union tag is ``access_error``. :rtype: bool """ return self._tag == 'access_error' def is_not_on_team(self): """ Check if the union tag is ``not_on_team``. :rtype: bool """ return self._tag == 'not_on_team' def is_team_policy_disallows_member_policy(self): """ Check if the union tag is ``team_policy_disallows_member_policy``. :rtype: bool """ return self._tag == 'team_policy_disallows_member_policy' def is_disallowed_shared_link_policy(self): """ Check if the union tag is ``disallowed_shared_link_policy``. :rtype: bool """ return self._tag == 'disallowed_shared_link_policy' def is_no_permission(self): """ Check if the union tag is ``no_permission``. :rtype: bool """ return self._tag == 'no_permission' def is_team_folder(self): """ Check if the union tag is ``team_folder``. :rtype: bool """ return self._tag == 'team_folder' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def get_access_error(self): """ Only call this if :meth:`is_access_error` is true. :rtype: SharedFolderAccessError """ if not self.is_access_error(): raise AttributeError("tag 'access_error' not set") return self._value def __repr__(self): return 'UpdateFolderPolicyError(%r, %r)' % (self._tag, self._value) UpdateFolderPolicyError_validator = bv.Union(UpdateFolderPolicyError) class UserMembershipInfo(MembershipInfo): """ The information about a user member of the shared content. :ivar user: The account information for the membership user. """ __slots__ = [ '_user_value', '_user_present', ] _has_required_fields = True def __init__(self, access_type=None, user=None, permissions=None, initials=None, is_inherited=None): super(UserMembershipInfo, self).__init__(access_type, permissions, initials, is_inherited) self._user_value = None self._user_present = False if user is not None: self.user = user @property def user(self): """ The account information for the membership user. :rtype: UserInfo """ if self._user_present: return self._user_value else: raise AttributeError("missing required field 'user'") @user.setter def user(self, val): self._user_validator.validate_type_only(val) self._user_value = val self._user_present = True @user.deleter def user(self): self._user_value = None self._user_present = False def __repr__(self): return 'UserMembershipInfo(access_type={!r}, user={!r}, permissions={!r}, initials={!r}, is_inherited={!r})'.format( self._access_type_value, self._user_value, self._permissions_value, self._initials_value, self._is_inherited_value, ) UserMembershipInfo_validator = bv.Struct(UserMembershipInfo) class UserFileMembershipInfo(UserMembershipInfo): """ The information about a user member of the shared content with an appended last seen timestamp. :ivar time_last_seen: The UTC timestamp of when the user has last seen the content, if they have. """ __slots__ = [ '_time_last_seen_value', '_time_last_seen_present', ] _has_required_fields = True def __init__(self, access_type=None, user=None, permissions=None, initials=None, is_inherited=None, time_last_seen=None): super(UserFileMembershipInfo, self).__init__(access_type, user, permissions, initials, is_inherited) self._time_last_seen_value = None self._time_last_seen_present = False if time_last_seen is not None: self.time_last_seen = time_last_seen @property def time_last_seen(self): """ The UTC timestamp of when the user has last seen the content, if they have. :rtype: datetime.datetime """ if self._time_last_seen_present: return self._time_last_seen_value else: return None @time_last_seen.setter def time_last_seen(self, val): if val is None: del self.time_last_seen return val = self._time_last_seen_validator.validate(val) self._time_last_seen_value = val self._time_last_seen_present = True @time_last_seen.deleter def time_last_seen(self): self._time_last_seen_value = None self._time_last_seen_present = False def __repr__(self): return 'UserFileMembershipInfo(access_type={!r}, user={!r}, permissions={!r}, initials={!r}, is_inherited={!r}, time_last_seen={!r})'.format( self._access_type_value, self._user_value, self._permissions_value, self._initials_value, self._is_inherited_value, self._time_last_seen_value, ) UserFileMembershipInfo_validator = bv.Struct(UserFileMembershipInfo) class UserInfo(object): """ Basic information about a user. Use :meth:`dropbox.dropbox.Dropbox.sharing_users_account` and :meth:`dropbox.dropbox.Dropbox.sharing_users_account_batch` to obtain more detailed information. :ivar account_id: The account ID of the user. :ivar same_team: If the user is in the same team as current user. :ivar team_member_id: The team member ID of the shared folder member. Only present if ``same_team`` is true. """ __slots__ = [ '_account_id_value', '_account_id_present', '_same_team_value', '_same_team_present', '_team_member_id_value', '_team_member_id_present', ] _has_required_fields = True def __init__(self, account_id=None, same_team=None, team_member_id=None): self._account_id_value = None self._account_id_present = False self._same_team_value = None self._same_team_present = False self._team_member_id_value = None self._team_member_id_present = False if account_id is not None: self.account_id = account_id if same_team is not None: self.same_team = same_team if team_member_id is not None: self.team_member_id = team_member_id @property def account_id(self): """ The account ID of the user. :rtype: str """ if self._account_id_present: return self._account_id_value else: raise AttributeError("missing required field 'account_id'") @account_id.setter def account_id(self, val): val = self._account_id_validator.validate(val) self._account_id_value = val self._account_id_present = True @account_id.deleter def account_id(self): self._account_id_value = None self._account_id_present = False @property def same_team(self): """ If the user is in the same team as current user. :rtype: bool """ if self._same_team_present: return self._same_team_value else: raise AttributeError("missing required field 'same_team'") @same_team.setter def same_team(self, val): val = self._same_team_validator.validate(val) self._same_team_value = val self._same_team_present = True @same_team.deleter def same_team(self): self._same_team_value = None self._same_team_present = False @property def team_member_id(self): """ The team member ID of the shared folder member. Only present if ``same_team`` is true. :rtype: str """ if self._team_member_id_present: return self._team_member_id_value else: return None @team_member_id.setter def team_member_id(self, val): if val is None: del self.team_member_id return val = self._team_member_id_validator.validate(val) self._team_member_id_value = val self._team_member_id_present = True @team_member_id.deleter def team_member_id(self): self._team_member_id_value = None self._team_member_id_present = False def __repr__(self): return 'UserInfo(account_id={!r}, same_team={!r}, team_member_id={!r})'.format( self._account_id_value, self._same_team_value, self._team_member_id_value, ) UserInfo_validator = bv.Struct(UserInfo) class ViewerInfoPolicy(bb.Union): """ This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar enabled: Viewer information is available on this file. :ivar disabled: Viewer information is disabled on this file. """ _catch_all = 'other' # Attribute is overwritten below the class definition enabled = None # Attribute is overwritten below the class definition disabled = None # Attribute is overwritten below the class definition other = None def is_enabled(self): """ Check if the union tag is ``enabled``. :rtype: bool """ return self._tag == 'enabled' def is_disabled(self): """ Check if the union tag is ``disabled``. :rtype: bool """ return self._tag == 'disabled' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'ViewerInfoPolicy(%r, %r)' % (self._tag, self._value) ViewerInfoPolicy_validator = bv.Union(ViewerInfoPolicy) class Visibility(bb.Union): """ Who can access a shared link. The most open visibility is ``public``. The default depends on many aspects, such as team and user preferences and shared folder settings. This class acts as a tagged union. Only one of the ``is_*`` methods will return true. To get the associated value of a tag (if one exists), use the corresponding ``get_*`` method. :ivar public: Anyone who has received the link can access it. No login required. :ivar team_only: Only members of the same team can access the link. Login is required. :ivar password: A link-specific password is required to access the link. Login is not required. :ivar team_and_password: Only members of the same team who have the link-specific password can access the link. :ivar shared_folder_only: Only members of the shared folder containing the linked file can access the link. Login is required. """ _catch_all = 'other' # Attribute is overwritten below the class definition public = None # Attribute is overwritten below the class definition team_only = None # Attribute is overwritten below the class definition password = None # Attribute is overwritten below the class definition team_and_password = None # Attribute is overwritten below the class definition shared_folder_only = None # Attribute is overwritten below the class definition other = None def is_public(self): """ Check if the union tag is ``public``. :rtype: bool """ return self._tag == 'public' def is_team_only(self): """ Check if the union tag is ``team_only``. :rtype: bool """ return self._tag == 'team_only' def is_password(self): """ Check if the union tag is ``password``. :rtype: bool """ return self._tag == 'password' def is_team_and_password(self): """ Check if the union tag is ``team_and_password``. :rtype: bool """ return self._tag == 'team_and_password' def is_shared_folder_only(self): """ Check if the union tag is ``shared_folder_only``. :rtype: bool """ return self._tag == 'shared_folder_only' def is_other(self): """ Check if the union tag is ``other``. :rtype: bool """ return self._tag == 'other' def __repr__(self): return 'Visibility(%r, %r)' % (self._tag, self._value) Visibility_validator = bv.Union(Visibility) DropboxId_validator = bv.String(min_length=1) FileId_validator = bv.String(min_length=1, pattern=u'id:.*') GetSharedLinkFileArg_validator = GetSharedLinkMetadataArg_validator GetSharedLinkFileArg = GetSharedLinkMetadataArg Id_validator = files.Id_validator Path_validator = files.Path_validator PathOrId_validator = bv.String(min_length=1, pattern=u'((/|id:).*|nspath:[0-9]+:.*)|ns:[0-9]+(/.*)?') ReadPath_validator = files.ReadPath_validator Rev_validator = files.Rev_validator TeamInfo_validator = users.Team_validator TeamInfo = users.Team AccessLevel._owner_validator = bv.Void() AccessLevel._editor_validator = bv.Void() AccessLevel._viewer_validator = bv.Void() AccessLevel._viewer_no_comment_validator = bv.Void() AccessLevel._other_validator = bv.Void() AccessLevel._tagmap = { 'owner': AccessLevel._owner_validator, 'editor': AccessLevel._editor_validator, 'viewer': AccessLevel._viewer_validator, 'viewer_no_comment': AccessLevel._viewer_no_comment_validator, 'other': AccessLevel._other_validator, } AccessLevel.owner = AccessLevel('owner') AccessLevel.editor = AccessLevel('editor') AccessLevel.viewer = AccessLevel('viewer') AccessLevel.viewer_no_comment = AccessLevel('viewer_no_comment') AccessLevel.other = AccessLevel('other') AclUpdatePolicy._owner_validator = bv.Void() AclUpdatePolicy._editors_validator = bv.Void() AclUpdatePolicy._other_validator = bv.Void() AclUpdatePolicy._tagmap = { 'owner': AclUpdatePolicy._owner_validator, 'editors': AclUpdatePolicy._editors_validator, 'other': AclUpdatePolicy._other_validator, } AclUpdatePolicy.owner = AclUpdatePolicy('owner') AclUpdatePolicy.editors = AclUpdatePolicy('editors') AclUpdatePolicy.other = AclUpdatePolicy('other') AddFileMemberArgs._file_validator = PathOrId_validator AddFileMemberArgs._members_validator = bv.List(MemberSelector_validator) AddFileMemberArgs._custom_message_validator = bv.Nullable(bv.String()) AddFileMemberArgs._quiet_validator = bv.Boolean() AddFileMemberArgs._access_level_validator = AccessLevel_validator AddFileMemberArgs._add_message_as_comment_validator = bv.Boolean() AddFileMemberArgs._all_field_names_ = set([ 'file', 'members', 'custom_message', 'quiet', 'access_level', 'add_message_as_comment', ]) AddFileMemberArgs._all_fields_ = [ ('file', AddFileMemberArgs._file_validator), ('members', AddFileMemberArgs._members_validator), ('custom_message', AddFileMemberArgs._custom_message_validator), ('quiet', AddFileMemberArgs._quiet_validator), ('access_level', AddFileMemberArgs._access_level_validator), ('add_message_as_comment', AddFileMemberArgs._add_message_as_comment_validator), ] AddFileMemberError._user_error_validator = SharingUserError_validator AddFileMemberError._access_error_validator = SharingFileAccessError_validator AddFileMemberError._rate_limit_validator = bv.Void() AddFileMemberError._invalid_comment_validator = bv.Void() AddFileMemberError._other_validator = bv.Void() AddFileMemberError._tagmap = { 'user_error': AddFileMemberError._user_error_validator, 'access_error': AddFileMemberError._access_error_validator, 'rate_limit': AddFileMemberError._rate_limit_validator, 'invalid_comment': AddFileMemberError._invalid_comment_validator, 'other': AddFileMemberError._other_validator, } AddFileMemberError.rate_limit = AddFileMemberError('rate_limit') AddFileMemberError.invalid_comment = AddFileMemberError('invalid_comment') AddFileMemberError.other = AddFileMemberError('other') AddFolderMemberArg._shared_folder_id_validator = common.SharedFolderId_validator AddFolderMemberArg._members_validator = bv.List(AddMember_validator) AddFolderMemberArg._quiet_validator = bv.Boolean() AddFolderMemberArg._custom_message_validator = bv.Nullable(bv.String(min_length=1)) AddFolderMemberArg._all_field_names_ = set([ 'shared_folder_id', 'members', 'quiet', 'custom_message', ]) AddFolderMemberArg._all_fields_ = [ ('shared_folder_id', AddFolderMemberArg._shared_folder_id_validator), ('members', AddFolderMemberArg._members_validator), ('quiet', AddFolderMemberArg._quiet_validator), ('custom_message', AddFolderMemberArg._custom_message_validator), ] AddFolderMemberError._access_error_validator = SharedFolderAccessError_validator AddFolderMemberError._email_unverified_validator = bv.Void() AddFolderMemberError._bad_member_validator = AddMemberSelectorError_validator AddFolderMemberError._cant_share_outside_team_validator = bv.Void() AddFolderMemberError._too_many_members_validator = bv.UInt64() AddFolderMemberError._too_many_pending_invites_validator = bv.UInt64() AddFolderMemberError._rate_limit_validator = bv.Void() AddFolderMemberError._too_many_invitees_validator = bv.Void() AddFolderMemberError._insufficient_plan_validator = bv.Void() AddFolderMemberError._team_folder_validator = bv.Void() AddFolderMemberError._no_permission_validator = bv.Void() AddFolderMemberError._other_validator = bv.Void() AddFolderMemberError._tagmap = { 'access_error': AddFolderMemberError._access_error_validator, 'email_unverified': AddFolderMemberError._email_unverified_validator, 'bad_member': AddFolderMemberError._bad_member_validator, 'cant_share_outside_team': AddFolderMemberError._cant_share_outside_team_validator, 'too_many_members': AddFolderMemberError._too_many_members_validator, 'too_many_pending_invites': AddFolderMemberError._too_many_pending_invites_validator, 'rate_limit': AddFolderMemberError._rate_limit_validator, 'too_many_invitees': AddFolderMemberError._too_many_invitees_validator, 'insufficient_plan': AddFolderMemberError._insufficient_plan_validator, 'team_folder': AddFolderMemberError._team_folder_validator, 'no_permission': AddFolderMemberError._no_permission_validator, 'other': AddFolderMemberError._other_validator, } AddFolderMemberError.email_unverified = AddFolderMemberError('email_unverified') AddFolderMemberError.cant_share_outside_team = AddFolderMemberError('cant_share_outside_team') AddFolderMemberError.rate_limit = AddFolderMemberError('rate_limit') AddFolderMemberError.too_many_invitees = AddFolderMemberError('too_many_invitees') AddFolderMemberError.insufficient_plan = AddFolderMemberError('insufficient_plan') AddFolderMemberError.team_folder = AddFolderMemberError('team_folder') AddFolderMemberError.no_permission = AddFolderMemberError('no_permission') AddFolderMemberError.other = AddFolderMemberError('other') AddMember._member_validator = MemberSelector_validator AddMember._access_level_validator = AccessLevel_validator AddMember._all_field_names_ = set([ 'member', 'access_level', ]) AddMember._all_fields_ = [ ('member', AddMember._member_validator), ('access_level', AddMember._access_level_validator), ] AddMemberSelectorError._automatic_group_validator = bv.Void() AddMemberSelectorError._invalid_dropbox_id_validator = DropboxId_validator AddMemberSelectorError._invalid_email_validator = common.EmailAddress_validator AddMemberSelectorError._unverified_dropbox_id_validator = DropboxId_validator AddMemberSelectorError._group_deleted_validator = bv.Void() AddMemberSelectorError._group_not_on_team_validator = bv.Void() AddMemberSelectorError._other_validator = bv.Void() AddMemberSelectorError._tagmap = { 'automatic_group': AddMemberSelectorError._automatic_group_validator, 'invalid_dropbox_id': AddMemberSelectorError._invalid_dropbox_id_validator, 'invalid_email': AddMemberSelectorError._invalid_email_validator, 'unverified_dropbox_id': AddMemberSelectorError._unverified_dropbox_id_validator, 'group_deleted': AddMemberSelectorError._group_deleted_validator, 'group_not_on_team': AddMemberSelectorError._group_not_on_team_validator, 'other': AddMemberSelectorError._other_validator, } AddMemberSelectorError.automatic_group = AddMemberSelectorError('automatic_group') AddMemberSelectorError.group_deleted = AddMemberSelectorError('group_deleted') AddMemberSelectorError.group_not_on_team = AddMemberSelectorError('group_not_on_team') AddMemberSelectorError.other = AddMemberSelectorError('other') AudienceExceptionContentInfo._name_validator = bv.String() AudienceExceptionContentInfo._all_field_names_ = set(['name']) AudienceExceptionContentInfo._all_fields_ = [('name', AudienceExceptionContentInfo._name_validator)] AudienceExceptions._count_validator = bv.UInt32() AudienceExceptions._exceptions_validator = bv.List(AudienceExceptionContentInfo_validator) AudienceExceptions._all_field_names_ = set([ 'count', 'exceptions', ]) AudienceExceptions._all_fields_ = [ ('count', AudienceExceptions._count_validator), ('exceptions', AudienceExceptions._exceptions_validator), ] AudienceRestrictingSharedFolder._shared_folder_id_validator = common.SharedFolderId_validator AudienceRestrictingSharedFolder._name_validator = bv.String() AudienceRestrictingSharedFolder._audience_validator = LinkAudience_validator AudienceRestrictingSharedFolder._all_field_names_ = set([ 'shared_folder_id', 'name', 'audience', ]) AudienceRestrictingSharedFolder._all_fields_ = [ ('shared_folder_id', AudienceRestrictingSharedFolder._shared_folder_id_validator), ('name', AudienceRestrictingSharedFolder._name_validator), ('audience', AudienceRestrictingSharedFolder._audience_validator), ] ChangeFileMemberAccessArgs._file_validator = PathOrId_validator ChangeFileMemberAccessArgs._member_validator = MemberSelector_validator ChangeFileMemberAccessArgs._access_level_validator = AccessLevel_validator ChangeFileMemberAccessArgs._all_field_names_ = set([ 'file', 'member', 'access_level', ]) ChangeFileMemberAccessArgs._all_fields_ = [ ('file', ChangeFileMemberAccessArgs._file_validator), ('member', ChangeFileMemberAccessArgs._member_validator), ('access_level', ChangeFileMemberAccessArgs._access_level_validator), ] LinkMetadata._url_validator = bv.String() LinkMetadata._visibility_validator = Visibility_validator LinkMetadata._expires_validator = bv.Nullable(common.DropboxTimestamp_validator) LinkMetadata._field_names_ = set([ 'url', 'visibility', 'expires', ]) LinkMetadata._all_field_names_ = LinkMetadata._field_names_ LinkMetadata._fields_ = [ ('url', LinkMetadata._url_validator), ('visibility', LinkMetadata._visibility_validator), ('expires', LinkMetadata._expires_validator), ] LinkMetadata._all_fields_ = LinkMetadata._fields_ LinkMetadata._tag_to_subtype_ = { (u'path',): PathLinkMetadata_validator, (u'collection',): CollectionLinkMetadata_validator, } LinkMetadata._pytype_to_tag_and_subtype_ = { PathLinkMetadata: ((u'path',), PathLinkMetadata_validator), CollectionLinkMetadata: ((u'collection',), CollectionLinkMetadata_validator), } LinkMetadata._is_catch_all_ = True CollectionLinkMetadata._field_names_ = set([]) CollectionLinkMetadata._all_field_names_ = LinkMetadata._all_field_names_.union(CollectionLinkMetadata._field_names_) CollectionLinkMetadata._fields_ = [] CollectionLinkMetadata._all_fields_ = LinkMetadata._all_fields_ + CollectionLinkMetadata._fields_ CreateSharedLinkArg._path_validator = bv.String() CreateSharedLinkArg._short_url_validator = bv.Boolean() CreateSharedLinkArg._pending_upload_validator = bv.Nullable(PendingUploadMode_validator) CreateSharedLinkArg._all_field_names_ = set([ 'path', 'short_url', 'pending_upload', ]) CreateSharedLinkArg._all_fields_ = [ ('path', CreateSharedLinkArg._path_validator), ('short_url', CreateSharedLinkArg._short_url_validator), ('pending_upload', CreateSharedLinkArg._pending_upload_validator), ] CreateSharedLinkError._path_validator = files.LookupError_validator CreateSharedLinkError._other_validator = bv.Void() CreateSharedLinkError._tagmap = { 'path': CreateSharedLinkError._path_validator, 'other': CreateSharedLinkError._other_validator, } CreateSharedLinkError.other = CreateSharedLinkError('other') CreateSharedLinkWithSettingsArg._path_validator = ReadPath_validator CreateSharedLinkWithSettingsArg._settings_validator = bv.Nullable(SharedLinkSettings_validator) CreateSharedLinkWithSettingsArg._all_field_names_ = set([ 'path', 'settings', ]) CreateSharedLinkWithSettingsArg._all_fields_ = [ ('path', CreateSharedLinkWithSettingsArg._path_validator), ('settings', CreateSharedLinkWithSettingsArg._settings_validator), ] CreateSharedLinkWithSettingsError._path_validator = files.LookupError_validator CreateSharedLinkWithSettingsError._email_not_verified_validator = bv.Void() CreateSharedLinkWithSettingsError._shared_link_already_exists_validator = bv.Void() CreateSharedLinkWithSettingsError._settings_error_validator = SharedLinkSettingsError_validator CreateSharedLinkWithSettingsError._access_denied_validator = bv.Void() CreateSharedLinkWithSettingsError._tagmap = { 'path': CreateSharedLinkWithSettingsError._path_validator, 'email_not_verified': CreateSharedLinkWithSettingsError._email_not_verified_validator, 'shared_link_already_exists': CreateSharedLinkWithSettingsError._shared_link_already_exists_validator, 'settings_error': CreateSharedLinkWithSettingsError._settings_error_validator, 'access_denied': CreateSharedLinkWithSettingsError._access_denied_validator, } CreateSharedLinkWithSettingsError.email_not_verified = CreateSharedLinkWithSettingsError('email_not_verified') CreateSharedLinkWithSettingsError.shared_link_already_exists = CreateSharedLinkWithSettingsError('shared_link_already_exists') CreateSharedLinkWithSettingsError.access_denied = CreateSharedLinkWithSettingsError('access_denied') SharedContentLinkMetadataBase._access_level_validator = bv.Nullable(AccessLevel_validator) SharedContentLinkMetadataBase._audience_options_validator = bv.List(LinkAudience_validator) SharedContentLinkMetadataBase._audience_restricting_shared_folder_validator = bv.Nullable(AudienceRestrictingSharedFolder_validator) SharedContentLinkMetadataBase._current_audience_validator = LinkAudience_validator SharedContentLinkMetadataBase._expiry_validator = bv.Nullable(common.DropboxTimestamp_validator) SharedContentLinkMetadataBase._link_permissions_validator = bv.List(LinkPermission_validator) SharedContentLinkMetadataBase._password_protected_validator = bv.Boolean() SharedContentLinkMetadataBase._all_field_names_ = set([ 'access_level', 'audience_options', 'audience_restricting_shared_folder', 'current_audience', 'expiry', 'link_permissions', 'password_protected', ]) SharedContentLinkMetadataBase._all_fields_ = [ ('access_level', SharedContentLinkMetadataBase._access_level_validator), ('audience_options', SharedContentLinkMetadataBase._audience_options_validator), ('audience_restricting_shared_folder', SharedContentLinkMetadataBase._audience_restricting_shared_folder_validator), ('current_audience', SharedContentLinkMetadataBase._current_audience_validator), ('expiry', SharedContentLinkMetadataBase._expiry_validator), ('link_permissions', SharedContentLinkMetadataBase._link_permissions_validator), ('password_protected', SharedContentLinkMetadataBase._password_protected_validator), ] ExpectedSharedContentLinkMetadata._all_field_names_ = SharedContentLinkMetadataBase._all_field_names_.union(set([])) ExpectedSharedContentLinkMetadata._all_fields_ = SharedContentLinkMetadataBase._all_fields_ + [] FileAction._disable_viewer_info_validator = bv.Void() FileAction._edit_contents_validator = bv.Void() FileAction._enable_viewer_info_validator = bv.Void() FileAction._invite_viewer_validator = bv.Void() FileAction._invite_viewer_no_comment_validator = bv.Void() FileAction._unshare_validator = bv.Void() FileAction._relinquish_membership_validator = bv.Void() FileAction._share_link_validator = bv.Void() FileAction._create_link_validator = bv.Void() FileAction._other_validator = bv.Void() FileAction._tagmap = { 'disable_viewer_info': FileAction._disable_viewer_info_validator, 'edit_contents': FileAction._edit_contents_validator, 'enable_viewer_info': FileAction._enable_viewer_info_validator, 'invite_viewer': FileAction._invite_viewer_validator, 'invite_viewer_no_comment': FileAction._invite_viewer_no_comment_validator, 'unshare': FileAction._unshare_validator, 'relinquish_membership': FileAction._relinquish_membership_validator, 'share_link': FileAction._share_link_validator, 'create_link': FileAction._create_link_validator, 'other': FileAction._other_validator, } FileAction.disable_viewer_info = FileAction('disable_viewer_info') FileAction.edit_contents = FileAction('edit_contents') FileAction.enable_viewer_info = FileAction('enable_viewer_info') FileAction.invite_viewer = FileAction('invite_viewer') FileAction.invite_viewer_no_comment = FileAction('invite_viewer_no_comment') FileAction.unshare = FileAction('unshare') FileAction.relinquish_membership = FileAction('relinquish_membership') FileAction.share_link = FileAction('share_link') FileAction.create_link = FileAction('create_link') FileAction.other = FileAction('other') FileErrorResult._file_not_found_error_validator = files.Id_validator FileErrorResult._invalid_file_action_error_validator = files.Id_validator FileErrorResult._permission_denied_error_validator = files.Id_validator FileErrorResult._other_validator = bv.Void() FileErrorResult._tagmap = { 'file_not_found_error': FileErrorResult._file_not_found_error_validator, 'invalid_file_action_error': FileErrorResult._invalid_file_action_error_validator, 'permission_denied_error': FileErrorResult._permission_denied_error_validator, 'other': FileErrorResult._other_validator, } FileErrorResult.other = FileErrorResult('other') SharedLinkMetadata._url_validator = bv.String() SharedLinkMetadata._id_validator = bv.Nullable(Id_validator) SharedLinkMetadata._name_validator = bv.String() SharedLinkMetadata._expires_validator = bv.Nullable(common.DropboxTimestamp_validator) SharedLinkMetadata._path_lower_validator = bv.Nullable(bv.String()) SharedLinkMetadata._link_permissions_validator = LinkPermissions_validator SharedLinkMetadata._team_member_info_validator = bv.Nullable(TeamMemberInfo_validator) SharedLinkMetadata._content_owner_team_info_validator = bv.Nullable(TeamInfo_validator) SharedLinkMetadata._field_names_ = set([ 'url', 'id', 'name', 'expires', 'path_lower', 'link_permissions', 'team_member_info', 'content_owner_team_info', ]) SharedLinkMetadata._all_field_names_ = SharedLinkMetadata._field_names_ SharedLinkMetadata._fields_ = [ ('url', SharedLinkMetadata._url_validator), ('id', SharedLinkMetadata._id_validator), ('name', SharedLinkMetadata._name_validator), ('expires', SharedLinkMetadata._expires_validator), ('path_lower', SharedLinkMetadata._path_lower_validator), ('link_permissions', SharedLinkMetadata._link_permissions_validator), ('team_member_info', SharedLinkMetadata._team_member_info_validator), ('content_owner_team_info', SharedLinkMetadata._content_owner_team_info_validator), ] SharedLinkMetadata._all_fields_ = SharedLinkMetadata._fields_ SharedLinkMetadata._tag_to_subtype_ = { (u'file',): FileLinkMetadata_validator, (u'folder',): FolderLinkMetadata_validator, } SharedLinkMetadata._pytype_to_tag_and_subtype_ = { FileLinkMetadata: ((u'file',), FileLinkMetadata_validator), FolderLinkMetadata: ((u'folder',), FolderLinkMetadata_validator), } SharedLinkMetadata._is_catch_all_ = True FileLinkMetadata._client_modified_validator = common.DropboxTimestamp_validator FileLinkMetadata._server_modified_validator = common.DropboxTimestamp_validator FileLinkMetadata._rev_validator = Rev_validator FileLinkMetadata._size_validator = bv.UInt64() FileLinkMetadata._field_names_ = set([ 'client_modified', 'server_modified', 'rev', 'size', ]) FileLinkMetadata._all_field_names_ = SharedLinkMetadata._all_field_names_.union(FileLinkMetadata._field_names_) FileLinkMetadata._fields_ = [ ('client_modified', FileLinkMetadata._client_modified_validator), ('server_modified', FileLinkMetadata._server_modified_validator), ('rev', FileLinkMetadata._rev_validator), ('size', FileLinkMetadata._size_validator), ] FileLinkMetadata._all_fields_ = SharedLinkMetadata._all_fields_ + FileLinkMetadata._fields_ FileMemberActionError._invalid_member_validator = bv.Void() FileMemberActionError._no_permission_validator = bv.Void() FileMemberActionError._access_error_validator = SharingFileAccessError_validator FileMemberActionError._no_explicit_access_validator = MemberAccessLevelResult_validator FileMemberActionError._other_validator = bv.Void() FileMemberActionError._tagmap = { 'invalid_member': FileMemberActionError._invalid_member_validator, 'no_permission': FileMemberActionError._no_permission_validator, 'access_error': FileMemberActionError._access_error_validator, 'no_explicit_access': FileMemberActionError._no_explicit_access_validator, 'other': FileMemberActionError._other_validator, } FileMemberActionError.invalid_member = FileMemberActionError('invalid_member') FileMemberActionError.no_permission = FileMemberActionError('no_permission') FileMemberActionError.other = FileMemberActionError('other') FileMemberActionIndividualResult._success_validator = bv.Nullable(AccessLevel_validator) FileMemberActionIndividualResult._member_error_validator = FileMemberActionError_validator FileMemberActionIndividualResult._tagmap = { 'success': FileMemberActionIndividualResult._success_validator, 'member_error': FileMemberActionIndividualResult._member_error_validator, } FileMemberActionResult._member_validator = MemberSelector_validator FileMemberActionResult._result_validator = FileMemberActionIndividualResult_validator FileMemberActionResult._all_field_names_ = set([ 'member', 'result', ]) FileMemberActionResult._all_fields_ = [ ('member', FileMemberActionResult._member_validator), ('result', FileMemberActionResult._result_validator), ] FileMemberRemoveActionResult._success_validator = MemberAccessLevelResult_validator FileMemberRemoveActionResult._member_error_validator = FileMemberActionError_validator FileMemberRemoveActionResult._other_validator = bv.Void() FileMemberRemoveActionResult._tagmap = { 'success': FileMemberRemoveActionResult._success_validator, 'member_error': FileMemberRemoveActionResult._member_error_validator, 'other': FileMemberRemoveActionResult._other_validator, } FileMemberRemoveActionResult.other = FileMemberRemoveActionResult('other') FilePermission._action_validator = FileAction_validator FilePermission._allow_validator = bv.Boolean() FilePermission._reason_validator = bv.Nullable(PermissionDeniedReason_validator) FilePermission._all_field_names_ = set([ 'action', 'allow', 'reason', ]) FilePermission._all_fields_ = [ ('action', FilePermission._action_validator), ('allow', FilePermission._allow_validator), ('reason', FilePermission._reason_validator), ] FolderAction._change_options_validator = bv.Void() FolderAction._disable_viewer_info_validator = bv.Void() FolderAction._edit_contents_validator = bv.Void() FolderAction._enable_viewer_info_validator = bv.Void() FolderAction._invite_editor_validator = bv.Void() FolderAction._invite_viewer_validator = bv.Void() FolderAction._invite_viewer_no_comment_validator = bv.Void() FolderAction._relinquish_membership_validator = bv.Void() FolderAction._unmount_validator = bv.Void() FolderAction._unshare_validator = bv.Void() FolderAction._leave_a_copy_validator = bv.Void() FolderAction._share_link_validator = bv.Void() FolderAction._create_link_validator = bv.Void() FolderAction._other_validator = bv.Void() FolderAction._tagmap = { 'change_options': FolderAction._change_options_validator, 'disable_viewer_info': FolderAction._disable_viewer_info_validator, 'edit_contents': FolderAction._edit_contents_validator, 'enable_viewer_info': FolderAction._enable_viewer_info_validator, 'invite_editor': FolderAction._invite_editor_validator, 'invite_viewer': FolderAction._invite_viewer_validator, 'invite_viewer_no_comment': FolderAction._invite_viewer_no_comment_validator, 'relinquish_membership': FolderAction._relinquish_membership_validator, 'unmount': FolderAction._unmount_validator, 'unshare': FolderAction._unshare_validator, 'leave_a_copy': FolderAction._leave_a_copy_validator, 'share_link': FolderAction._share_link_validator, 'create_link': FolderAction._create_link_validator, 'other': FolderAction._other_validator, } FolderAction.change_options = FolderAction('change_options') FolderAction.disable_viewer_info = FolderAction('disable_viewer_info') FolderAction.edit_contents = FolderAction('edit_contents') FolderAction.enable_viewer_info = FolderAction('enable_viewer_info') FolderAction.invite_editor = FolderAction('invite_editor') FolderAction.invite_viewer = FolderAction('invite_viewer') FolderAction.invite_viewer_no_comment = FolderAction('invite_viewer_no_comment') FolderAction.relinquish_membership = FolderAction('relinquish_membership') FolderAction.unmount = FolderAction('unmount') FolderAction.unshare = FolderAction('unshare') FolderAction.leave_a_copy = FolderAction('leave_a_copy') FolderAction.share_link = FolderAction('share_link') FolderAction.create_link = FolderAction('create_link') FolderAction.other = FolderAction('other') FolderLinkMetadata._field_names_ = set([]) FolderLinkMetadata._all_field_names_ = SharedLinkMetadata._all_field_names_.union(FolderLinkMetadata._field_names_) FolderLinkMetadata._fields_ = [] FolderLinkMetadata._all_fields_ = SharedLinkMetadata._all_fields_ + FolderLinkMetadata._fields_ FolderPermission._action_validator = FolderAction_validator FolderPermission._allow_validator = bv.Boolean() FolderPermission._reason_validator = bv.Nullable(PermissionDeniedReason_validator) FolderPermission._all_field_names_ = set([ 'action', 'allow', 'reason', ]) FolderPermission._all_fields_ = [ ('action', FolderPermission._action_validator), ('allow', FolderPermission._allow_validator), ('reason', FolderPermission._reason_validator), ] FolderPolicy._member_policy_validator = bv.Nullable(MemberPolicy_validator) FolderPolicy._resolved_member_policy_validator = bv.Nullable(MemberPolicy_validator) FolderPolicy._acl_update_policy_validator = AclUpdatePolicy_validator FolderPolicy._shared_link_policy_validator = SharedLinkPolicy_validator FolderPolicy._viewer_info_policy_validator = bv.Nullable(ViewerInfoPolicy_validator) FolderPolicy._all_field_names_ = set([ 'member_policy', 'resolved_member_policy', 'acl_update_policy', 'shared_link_policy', 'viewer_info_policy', ]) FolderPolicy._all_fields_ = [ ('member_policy', FolderPolicy._member_policy_validator), ('resolved_member_policy', FolderPolicy._resolved_member_policy_validator), ('acl_update_policy', FolderPolicy._acl_update_policy_validator), ('shared_link_policy', FolderPolicy._shared_link_policy_validator), ('viewer_info_policy', FolderPolicy._viewer_info_policy_validator), ] GetFileMetadataArg._file_validator = PathOrId_validator GetFileMetadataArg._actions_validator = bv.Nullable(bv.List(FileAction_validator)) GetFileMetadataArg._all_field_names_ = set([ 'file', 'actions', ]) GetFileMetadataArg._all_fields_ = [ ('file', GetFileMetadataArg._file_validator), ('actions', GetFileMetadataArg._actions_validator), ] GetFileMetadataBatchArg._files_validator = bv.List(PathOrId_validator, max_items=100) GetFileMetadataBatchArg._actions_validator = bv.Nullable(bv.List(FileAction_validator)) GetFileMetadataBatchArg._all_field_names_ = set([ 'files', 'actions', ]) GetFileMetadataBatchArg._all_fields_ = [ ('files', GetFileMetadataBatchArg._files_validator), ('actions', GetFileMetadataBatchArg._actions_validator), ] GetFileMetadataBatchResult._file_validator = PathOrId_validator GetFileMetadataBatchResult._result_validator = GetFileMetadataIndividualResult_validator GetFileMetadataBatchResult._all_field_names_ = set([ 'file', 'result', ]) GetFileMetadataBatchResult._all_fields_ = [ ('file', GetFileMetadataBatchResult._file_validator), ('result', GetFileMetadataBatchResult._result_validator), ] GetFileMetadataError._user_error_validator = SharingUserError_validator GetFileMetadataError._access_error_validator = SharingFileAccessError_validator GetFileMetadataError._other_validator = bv.Void() GetFileMetadataError._tagmap = { 'user_error': GetFileMetadataError._user_error_validator, 'access_error': GetFileMetadataError._access_error_validator, 'other': GetFileMetadataError._other_validator, } GetFileMetadataError.other = GetFileMetadataError('other') GetFileMetadataIndividualResult._metadata_validator = SharedFileMetadata_validator GetFileMetadataIndividualResult._access_error_validator = SharingFileAccessError_validator GetFileMetadataIndividualResult._other_validator = bv.Void() GetFileMetadataIndividualResult._tagmap = { 'metadata': GetFileMetadataIndividualResult._metadata_validator, 'access_error': GetFileMetadataIndividualResult._access_error_validator, 'other': GetFileMetadataIndividualResult._other_validator, } GetFileMetadataIndividualResult.other = GetFileMetadataIndividualResult('other') GetMetadataArgs._shared_folder_id_validator = common.SharedFolderId_validator GetMetadataArgs._actions_validator = bv.Nullable(bv.List(FolderAction_validator)) GetMetadataArgs._all_field_names_ = set([ 'shared_folder_id', 'actions', ]) GetMetadataArgs._all_fields_ = [ ('shared_folder_id', GetMetadataArgs._shared_folder_id_validator), ('actions', GetMetadataArgs._actions_validator), ] SharedLinkError._shared_link_not_found_validator = bv.Void() SharedLinkError._shared_link_access_denied_validator = bv.Void() SharedLinkError._unsupported_link_type_validator = bv.Void() SharedLinkError._other_validator = bv.Void() SharedLinkError._tagmap = { 'shared_link_not_found': SharedLinkError._shared_link_not_found_validator, 'shared_link_access_denied': SharedLinkError._shared_link_access_denied_validator, 'unsupported_link_type': SharedLinkError._unsupported_link_type_validator, 'other': SharedLinkError._other_validator, } SharedLinkError.shared_link_not_found = SharedLinkError('shared_link_not_found') SharedLinkError.shared_link_access_denied = SharedLinkError('shared_link_access_denied') SharedLinkError.unsupported_link_type = SharedLinkError('unsupported_link_type') SharedLinkError.other = SharedLinkError('other') GetSharedLinkFileError._shared_link_is_directory_validator = bv.Void() GetSharedLinkFileError._tagmap = { 'shared_link_is_directory': GetSharedLinkFileError._shared_link_is_directory_validator, } GetSharedLinkFileError._tagmap.update(SharedLinkError._tagmap) GetSharedLinkFileError.shared_link_is_directory = GetSharedLinkFileError('shared_link_is_directory') GetSharedLinkMetadataArg._url_validator = bv.String() GetSharedLinkMetadataArg._path_validator = bv.Nullable(Path_validator) GetSharedLinkMetadataArg._link_password_validator = bv.Nullable(bv.String()) GetSharedLinkMetadataArg._all_field_names_ = set([ 'url', 'path', 'link_password', ]) GetSharedLinkMetadataArg._all_fields_ = [ ('url', GetSharedLinkMetadataArg._url_validator), ('path', GetSharedLinkMetadataArg._path_validator), ('link_password', GetSharedLinkMetadataArg._link_password_validator), ] GetSharedLinksArg._path_validator = bv.Nullable(bv.String()) GetSharedLinksArg._all_field_names_ = set(['path']) GetSharedLinksArg._all_fields_ = [('path', GetSharedLinksArg._path_validator)] GetSharedLinksError._path_validator = files.MalformedPathError_validator GetSharedLinksError._other_validator = bv.Void() GetSharedLinksError._tagmap = { 'path': GetSharedLinksError._path_validator, 'other': GetSharedLinksError._other_validator, } GetSharedLinksError.other = GetSharedLinksError('other') GetSharedLinksResult._links_validator = bv.List(LinkMetadata_validator) GetSharedLinksResult._all_field_names_ = set(['links']) GetSharedLinksResult._all_fields_ = [('links', GetSharedLinksResult._links_validator)] GroupInfo._group_type_validator = team_common.GroupType_validator GroupInfo._is_member_validator = bv.Boolean() GroupInfo._is_owner_validator = bv.Boolean() GroupInfo._same_team_validator = bv.Boolean() GroupInfo._all_field_names_ = team_common.GroupSummary._all_field_names_.union(set([ 'group_type', 'is_member', 'is_owner', 'same_team', ])) GroupInfo._all_fields_ = team_common.GroupSummary._all_fields_ + [ ('group_type', GroupInfo._group_type_validator), ('is_member', GroupInfo._is_member_validator), ('is_owner', GroupInfo._is_owner_validator), ('same_team', GroupInfo._same_team_validator), ] MembershipInfo._access_type_validator = AccessLevel_validator MembershipInfo._permissions_validator = bv.Nullable(bv.List(MemberPermission_validator)) MembershipInfo._initials_validator = bv.Nullable(bv.String()) MembershipInfo._is_inherited_validator = bv.Boolean() MembershipInfo._all_field_names_ = set([ 'access_type', 'permissions', 'initials', 'is_inherited', ]) MembershipInfo._all_fields_ = [ ('access_type', MembershipInfo._access_type_validator), ('permissions', MembershipInfo._permissions_validator), ('initials', MembershipInfo._initials_validator), ('is_inherited', MembershipInfo._is_inherited_validator), ] GroupMembershipInfo._group_validator = GroupInfo_validator GroupMembershipInfo._all_field_names_ = MembershipInfo._all_field_names_.union(set(['group'])) GroupMembershipInfo._all_fields_ = MembershipInfo._all_fields_ + [('group', GroupMembershipInfo._group_validator)] InsufficientPlan._message_validator = bv.String() InsufficientPlan._upsell_url_validator = bv.Nullable(bv.String()) InsufficientPlan._all_field_names_ = set([ 'message', 'upsell_url', ]) InsufficientPlan._all_fields_ = [ ('message', InsufficientPlan._message_validator), ('upsell_url', InsufficientPlan._upsell_url_validator), ] InsufficientQuotaAmounts._space_needed_validator = bv.UInt64() InsufficientQuotaAmounts._space_shortage_validator = bv.UInt64() InsufficientQuotaAmounts._space_left_validator = bv.UInt64() InsufficientQuotaAmounts._all_field_names_ = set([ 'space_needed', 'space_shortage', 'space_left', ]) InsufficientQuotaAmounts._all_fields_ = [ ('space_needed', InsufficientQuotaAmounts._space_needed_validator), ('space_shortage', InsufficientQuotaAmounts._space_shortage_validator), ('space_left', InsufficientQuotaAmounts._space_left_validator), ] InviteeInfo._email_validator = common.EmailAddress_validator InviteeInfo._other_validator = bv.Void() InviteeInfo._tagmap = { 'email': InviteeInfo._email_validator, 'other': InviteeInfo._other_validator, } InviteeInfo.other = InviteeInfo('other') InviteeMembershipInfo._invitee_validator = InviteeInfo_validator InviteeMembershipInfo._user_validator = bv.Nullable(UserInfo_validator) InviteeMembershipInfo._all_field_names_ = MembershipInfo._all_field_names_.union(set([ 'invitee', 'user', ])) InviteeMembershipInfo._all_fields_ = MembershipInfo._all_fields_ + [ ('invitee', InviteeMembershipInfo._invitee_validator), ('user', InviteeMembershipInfo._user_validator), ] JobError._unshare_folder_error_validator = UnshareFolderError_validator JobError._remove_folder_member_error_validator = RemoveFolderMemberError_validator JobError._relinquish_folder_membership_error_validator = RelinquishFolderMembershipError_validator JobError._other_validator = bv.Void() JobError._tagmap = { 'unshare_folder_error': JobError._unshare_folder_error_validator, 'remove_folder_member_error': JobError._remove_folder_member_error_validator, 'relinquish_folder_membership_error': JobError._relinquish_folder_membership_error_validator, 'other': JobError._other_validator, } JobError.other = JobError('other') JobStatus._complete_validator = bv.Void() JobStatus._failed_validator = JobError_validator JobStatus._tagmap = { 'complete': JobStatus._complete_validator, 'failed': JobStatus._failed_validator, } JobStatus._tagmap.update(async.PollResultBase._tagmap) JobStatus.complete = JobStatus('complete') LinkAction._change_access_level_validator = bv.Void() LinkAction._change_audience_validator = bv.Void() LinkAction._remove_expiry_validator = bv.Void() LinkAction._remove_password_validator = bv.Void() LinkAction._set_expiry_validator = bv.Void() LinkAction._set_password_validator = bv.Void() LinkAction._other_validator = bv.Void() LinkAction._tagmap = { 'change_access_level': LinkAction._change_access_level_validator, 'change_audience': LinkAction._change_audience_validator, 'remove_expiry': LinkAction._remove_expiry_validator, 'remove_password': LinkAction._remove_password_validator, 'set_expiry': LinkAction._set_expiry_validator, 'set_password': LinkAction._set_password_validator, 'other': LinkAction._other_validator, } LinkAction.change_access_level = LinkAction('change_access_level') LinkAction.change_audience = LinkAction('change_audience') LinkAction.remove_expiry = LinkAction('remove_expiry') LinkAction.remove_password = LinkAction('remove_password') LinkAction.set_expiry = LinkAction('set_expiry') LinkAction.set_password = LinkAction('set_password') LinkAction.other = LinkAction('other') LinkAudience._public_validator = bv.Void() LinkAudience._team_validator = bv.Void() LinkAudience._members_validator = bv.Void() LinkAudience._other_validator = bv.Void() LinkAudience._tagmap = { 'public': LinkAudience._public_validator, 'team': LinkAudience._team_validator, 'members': LinkAudience._members_validator, 'other': LinkAudience._other_validator, } LinkAudience.public = LinkAudience('public') LinkAudience.team = LinkAudience('team') LinkAudience.members = LinkAudience('members') LinkAudience.other = LinkAudience('other') LinkExpiry._remove_expiry_validator = bv.Void() LinkExpiry._set_expiry_validator = common.DropboxTimestamp_validator LinkExpiry._other_validator = bv.Void() LinkExpiry._tagmap = { 'remove_expiry': LinkExpiry._remove_expiry_validator, 'set_expiry': LinkExpiry._set_expiry_validator, 'other': LinkExpiry._other_validator, } LinkExpiry.remove_expiry = LinkExpiry('remove_expiry') LinkExpiry.other = LinkExpiry('other') LinkPassword._remove_password_validator = bv.Void() LinkPassword._set_password_validator = bv.String() LinkPassword._other_validator = bv.Void() LinkPassword._tagmap = { 'remove_password': LinkPassword._remove_password_validator, 'set_password': LinkPassword._set_password_validator, 'other': LinkPassword._other_validator, } LinkPassword.remove_password = LinkPassword('remove_password') LinkPassword.other = LinkPassword('other') LinkPermission._action_validator = LinkAction_validator LinkPermission._allow_validator = bv.Boolean() LinkPermission._reason_validator = bv.Nullable(PermissionDeniedReason_validator) LinkPermission._all_field_names_ = set([ 'action', 'allow', 'reason', ]) LinkPermission._all_fields_ = [ ('action', LinkPermission._action_validator), ('allow', LinkPermission._allow_validator), ('reason', LinkPermission._reason_validator), ] LinkPermissions._resolved_visibility_validator = bv.Nullable(ResolvedVisibility_validator) LinkPermissions._requested_visibility_validator = bv.Nullable(RequestedVisibility_validator) LinkPermissions._can_revoke_validator = bv.Boolean() LinkPermissions._revoke_failure_reason_validator = bv.Nullable(SharedLinkAccessFailureReason_validator) LinkPermissions._all_field_names_ = set([ 'resolved_visibility', 'requested_visibility', 'can_revoke', 'revoke_failure_reason', ]) LinkPermissions._all_fields_ = [ ('resolved_visibility', LinkPermissions._resolved_visibility_validator), ('requested_visibility', LinkPermissions._requested_visibility_validator), ('can_revoke', LinkPermissions._can_revoke_validator), ('revoke_failure_reason', LinkPermissions._revoke_failure_reason_validator), ] LinkSettings._access_level_validator = bv.Nullable(AccessLevel_validator) LinkSettings._audience_validator = bv.Nullable(LinkAudience_validator) LinkSettings._expiry_validator = bv.Nullable(LinkExpiry_validator) LinkSettings._password_validator = bv.Nullable(LinkPassword_validator) LinkSettings._all_field_names_ = set([ 'access_level', 'audience', 'expiry', 'password', ]) LinkSettings._all_fields_ = [ ('access_level', LinkSettings._access_level_validator), ('audience', LinkSettings._audience_validator), ('expiry', LinkSettings._expiry_validator), ('password', LinkSettings._password_validator), ] ListFileMembersArg._file_validator = PathOrId_validator ListFileMembersArg._actions_validator = bv.Nullable(bv.List(MemberAction_validator)) ListFileMembersArg._include_inherited_validator = bv.Boolean() ListFileMembersArg._limit_validator = bv.UInt32(min_value=1, max_value=300) ListFileMembersArg._all_field_names_ = set([ 'file', 'actions', 'include_inherited', 'limit', ]) ListFileMembersArg._all_fields_ = [ ('file', ListFileMembersArg._file_validator), ('actions', ListFileMembersArg._actions_validator), ('include_inherited', ListFileMembersArg._include_inherited_validator), ('limit', ListFileMembersArg._limit_validator), ] ListFileMembersBatchArg._files_validator = bv.List(PathOrId_validator, max_items=100) ListFileMembersBatchArg._limit_validator = bv.UInt32(max_value=20) ListFileMembersBatchArg._all_field_names_ = set([ 'files', 'limit', ]) ListFileMembersBatchArg._all_fields_ = [ ('files', ListFileMembersBatchArg._files_validator), ('limit', ListFileMembersBatchArg._limit_validator), ] ListFileMembersBatchResult._file_validator = PathOrId_validator ListFileMembersBatchResult._result_validator = ListFileMembersIndividualResult_validator ListFileMembersBatchResult._all_field_names_ = set([ 'file', 'result', ]) ListFileMembersBatchResult._all_fields_ = [ ('file', ListFileMembersBatchResult._file_validator), ('result', ListFileMembersBatchResult._result_validator), ] ListFileMembersContinueArg._cursor_validator = bv.String() ListFileMembersContinueArg._all_field_names_ = set(['cursor']) ListFileMembersContinueArg._all_fields_ = [('cursor', ListFileMembersContinueArg._cursor_validator)] ListFileMembersContinueError._user_error_validator = SharingUserError_validator ListFileMembersContinueError._access_error_validator = SharingFileAccessError_validator ListFileMembersContinueError._invalid_cursor_validator = bv.Void() ListFileMembersContinueError._other_validator = bv.Void() ListFileMembersContinueError._tagmap = { 'user_error': ListFileMembersContinueError._user_error_validator, 'access_error': ListFileMembersContinueError._access_error_validator, 'invalid_cursor': ListFileMembersContinueError._invalid_cursor_validator, 'other': ListFileMembersContinueError._other_validator, } ListFileMembersContinueError.invalid_cursor = ListFileMembersContinueError('invalid_cursor') ListFileMembersContinueError.other = ListFileMembersContinueError('other') ListFileMembersCountResult._members_validator = SharedFileMembers_validator ListFileMembersCountResult._member_count_validator = bv.UInt32() ListFileMembersCountResult._all_field_names_ = set([ 'members', 'member_count', ]) ListFileMembersCountResult._all_fields_ = [ ('members', ListFileMembersCountResult._members_validator), ('member_count', ListFileMembersCountResult._member_count_validator), ] ListFileMembersError._user_error_validator = SharingUserError_validator ListFileMembersError._access_error_validator = SharingFileAccessError_validator ListFileMembersError._other_validator = bv.Void() ListFileMembersError._tagmap = { 'user_error': ListFileMembersError._user_error_validator, 'access_error': ListFileMembersError._access_error_validator, 'other': ListFileMembersError._other_validator, } ListFileMembersError.other = ListFileMembersError('other') ListFileMembersIndividualResult._result_validator = ListFileMembersCountResult_validator ListFileMembersIndividualResult._access_error_validator = SharingFileAccessError_validator ListFileMembersIndividualResult._other_validator = bv.Void() ListFileMembersIndividualResult._tagmap = { 'result': ListFileMembersIndividualResult._result_validator, 'access_error': ListFileMembersIndividualResult._access_error_validator, 'other': ListFileMembersIndividualResult._other_validator, } ListFileMembersIndividualResult.other = ListFileMembersIndividualResult('other') ListFilesArg._limit_validator = bv.UInt32(min_value=1, max_value=300) ListFilesArg._actions_validator = bv.Nullable(bv.List(FileAction_validator)) ListFilesArg._all_field_names_ = set([ 'limit', 'actions', ]) ListFilesArg._all_fields_ = [ ('limit', ListFilesArg._limit_validator), ('actions', ListFilesArg._actions_validator), ] ListFilesContinueArg._cursor_validator = bv.String() ListFilesContinueArg._all_field_names_ = set(['cursor']) ListFilesContinueArg._all_fields_ = [('cursor', ListFilesContinueArg._cursor_validator)] ListFilesContinueError._user_error_validator = SharingUserError_validator ListFilesContinueError._invalid_cursor_validator = bv.Void() ListFilesContinueError._other_validator = bv.Void() ListFilesContinueError._tagmap = { 'user_error': ListFilesContinueError._user_error_validator, 'invalid_cursor': ListFilesContinueError._invalid_cursor_validator, 'other': ListFilesContinueError._other_validator, } ListFilesContinueError.invalid_cursor = ListFilesContinueError('invalid_cursor') ListFilesContinueError.other = ListFilesContinueError('other') ListFilesResult._entries_validator = bv.List(SharedFileMetadata_validator) ListFilesResult._cursor_validator = bv.Nullable(bv.String()) ListFilesResult._all_field_names_ = set([ 'entries', 'cursor', ]) ListFilesResult._all_fields_ = [ ('entries', ListFilesResult._entries_validator), ('cursor', ListFilesResult._cursor_validator), ] ListFolderMembersCursorArg._actions_validator = bv.Nullable(bv.List(MemberAction_validator)) ListFolderMembersCursorArg._limit_validator = bv.UInt32(min_value=1, max_value=1000) ListFolderMembersCursorArg._all_field_names_ = set([ 'actions', 'limit', ]) ListFolderMembersCursorArg._all_fields_ = [ ('actions', ListFolderMembersCursorArg._actions_validator), ('limit', ListFolderMembersCursorArg._limit_validator), ] ListFolderMembersArgs._shared_folder_id_validator = common.SharedFolderId_validator ListFolderMembersArgs._all_field_names_ = ListFolderMembersCursorArg._all_field_names_.union(set(['shared_folder_id'])) ListFolderMembersArgs._all_fields_ = ListFolderMembersCursorArg._all_fields_ + [('shared_folder_id', ListFolderMembersArgs._shared_folder_id_validator)] ListFolderMembersContinueArg._cursor_validator = bv.String() ListFolderMembersContinueArg._all_field_names_ = set(['cursor']) ListFolderMembersContinueArg._all_fields_ = [('cursor', ListFolderMembersContinueArg._cursor_validator)] ListFolderMembersContinueError._access_error_validator = SharedFolderAccessError_validator ListFolderMembersContinueError._invalid_cursor_validator = bv.Void() ListFolderMembersContinueError._other_validator = bv.Void() ListFolderMembersContinueError._tagmap = { 'access_error': ListFolderMembersContinueError._access_error_validator, 'invalid_cursor': ListFolderMembersContinueError._invalid_cursor_validator, 'other': ListFolderMembersContinueError._other_validator, } ListFolderMembersContinueError.invalid_cursor = ListFolderMembersContinueError('invalid_cursor') ListFolderMembersContinueError.other = ListFolderMembersContinueError('other') ListFoldersArgs._limit_validator = bv.UInt32(min_value=1, max_value=1000) ListFoldersArgs._actions_validator = bv.Nullable(bv.List(FolderAction_validator)) ListFoldersArgs._all_field_names_ = set([ 'limit', 'actions', ]) ListFoldersArgs._all_fields_ = [ ('limit', ListFoldersArgs._limit_validator), ('actions', ListFoldersArgs._actions_validator), ] ListFoldersContinueArg._cursor_validator = bv.String() ListFoldersContinueArg._all_field_names_ = set(['cursor']) ListFoldersContinueArg._all_fields_ = [('cursor', ListFoldersContinueArg._cursor_validator)] ListFoldersContinueError._invalid_cursor_validator = bv.Void() ListFoldersContinueError._other_validator = bv.Void() ListFoldersContinueError._tagmap = { 'invalid_cursor': ListFoldersContinueError._invalid_cursor_validator, 'other': ListFoldersContinueError._other_validator, } ListFoldersContinueError.invalid_cursor = ListFoldersContinueError('invalid_cursor') ListFoldersContinueError.other = ListFoldersContinueError('other') ListFoldersResult._entries_validator = bv.List(SharedFolderMetadata_validator) ListFoldersResult._cursor_validator = bv.Nullable(bv.String()) ListFoldersResult._all_field_names_ = set([ 'entries', 'cursor', ]) ListFoldersResult._all_fields_ = [ ('entries', ListFoldersResult._entries_validator), ('cursor', ListFoldersResult._cursor_validator), ] ListSharedLinksArg._path_validator = bv.Nullable(ReadPath_validator) ListSharedLinksArg._cursor_validator = bv.Nullable(bv.String()) ListSharedLinksArg._direct_only_validator = bv.Nullable(bv.Boolean()) ListSharedLinksArg._all_field_names_ = set([ 'path', 'cursor', 'direct_only', ]) ListSharedLinksArg._all_fields_ = [ ('path', ListSharedLinksArg._path_validator), ('cursor', ListSharedLinksArg._cursor_validator), ('direct_only', ListSharedLinksArg._direct_only_validator), ] ListSharedLinksError._path_validator = files.LookupError_validator ListSharedLinksError._reset_validator = bv.Void() ListSharedLinksError._other_validator = bv.Void() ListSharedLinksError._tagmap = { 'path': ListSharedLinksError._path_validator, 'reset': ListSharedLinksError._reset_validator, 'other': ListSharedLinksError._other_validator, } ListSharedLinksError.reset = ListSharedLinksError('reset') ListSharedLinksError.other = ListSharedLinksError('other') ListSharedLinksResult._links_validator = bv.List(SharedLinkMetadata_validator) ListSharedLinksResult._has_more_validator = bv.Boolean() ListSharedLinksResult._cursor_validator = bv.Nullable(bv.String()) ListSharedLinksResult._all_field_names_ = set([ 'links', 'has_more', 'cursor', ]) ListSharedLinksResult._all_fields_ = [ ('links', ListSharedLinksResult._links_validator), ('has_more', ListSharedLinksResult._has_more_validator), ('cursor', ListSharedLinksResult._cursor_validator), ] MemberAccessLevelResult._access_level_validator = bv.Nullable(AccessLevel_validator) MemberAccessLevelResult._warning_validator = bv.Nullable(bv.String()) MemberAccessLevelResult._access_details_validator = bv.Nullable(bv.List(ParentFolderAccessInfo_validator)) MemberAccessLevelResult._all_field_names_ = set([ 'access_level', 'warning', 'access_details', ]) MemberAccessLevelResult._all_fields_ = [ ('access_level', MemberAccessLevelResult._access_level_validator), ('warning', MemberAccessLevelResult._warning_validator), ('access_details', MemberAccessLevelResult._access_details_validator), ] MemberAction._leave_a_copy_validator = bv.Void() MemberAction._make_editor_validator = bv.Void() MemberAction._make_owner_validator = bv.Void() MemberAction._make_viewer_validator = bv.Void() MemberAction._make_viewer_no_comment_validator = bv.Void() MemberAction._remove_validator = bv.Void() MemberAction._other_validator = bv.Void() MemberAction._tagmap = { 'leave_a_copy': MemberAction._leave_a_copy_validator, 'make_editor': MemberAction._make_editor_validator, 'make_owner': MemberAction._make_owner_validator, 'make_viewer': MemberAction._make_viewer_validator, 'make_viewer_no_comment': MemberAction._make_viewer_no_comment_validator, 'remove': MemberAction._remove_validator, 'other': MemberAction._other_validator, } MemberAction.leave_a_copy = MemberAction('leave_a_copy') MemberAction.make_editor = MemberAction('make_editor') MemberAction.make_owner = MemberAction('make_owner') MemberAction.make_viewer = MemberAction('make_viewer') MemberAction.make_viewer_no_comment = MemberAction('make_viewer_no_comment') MemberAction.remove = MemberAction('remove') MemberAction.other = MemberAction('other') MemberPermission._action_validator = MemberAction_validator MemberPermission._allow_validator = bv.Boolean() MemberPermission._reason_validator = bv.Nullable(PermissionDeniedReason_validator) MemberPermission._all_field_names_ = set([ 'action', 'allow', 'reason', ]) MemberPermission._all_fields_ = [ ('action', MemberPermission._action_validator), ('allow', MemberPermission._allow_validator), ('reason', MemberPermission._reason_validator), ] MemberPolicy._team_validator = bv.Void() MemberPolicy._anyone_validator = bv.Void() MemberPolicy._other_validator = bv.Void() MemberPolicy._tagmap = { 'team': MemberPolicy._team_validator, 'anyone': MemberPolicy._anyone_validator, 'other': MemberPolicy._other_validator, } MemberPolicy.team = MemberPolicy('team') MemberPolicy.anyone = MemberPolicy('anyone') MemberPolicy.other = MemberPolicy('other') MemberSelector._dropbox_id_validator = DropboxId_validator MemberSelector._email_validator = common.EmailAddress_validator MemberSelector._other_validator = bv.Void() MemberSelector._tagmap = { 'dropbox_id': MemberSelector._dropbox_id_validator, 'email': MemberSelector._email_validator, 'other': MemberSelector._other_validator, } MemberSelector.other = MemberSelector('other') ModifySharedLinkSettingsArgs._url_validator = bv.String() ModifySharedLinkSettingsArgs._settings_validator = SharedLinkSettings_validator ModifySharedLinkSettingsArgs._remove_expiration_validator = bv.Boolean() ModifySharedLinkSettingsArgs._all_field_names_ = set([ 'url', 'settings', 'remove_expiration', ]) ModifySharedLinkSettingsArgs._all_fields_ = [ ('url', ModifySharedLinkSettingsArgs._url_validator), ('settings', ModifySharedLinkSettingsArgs._settings_validator), ('remove_expiration', ModifySharedLinkSettingsArgs._remove_expiration_validator), ] ModifySharedLinkSettingsError._settings_error_validator = SharedLinkSettingsError_validator ModifySharedLinkSettingsError._email_not_verified_validator = bv.Void() ModifySharedLinkSettingsError._tagmap = { 'settings_error': ModifySharedLinkSettingsError._settings_error_validator, 'email_not_verified': ModifySharedLinkSettingsError._email_not_verified_validator, } ModifySharedLinkSettingsError._tagmap.update(SharedLinkError._tagmap) ModifySharedLinkSettingsError.email_not_verified = ModifySharedLinkSettingsError('email_not_verified') MountFolderArg._shared_folder_id_validator = common.SharedFolderId_validator MountFolderArg._all_field_names_ = set(['shared_folder_id']) MountFolderArg._all_fields_ = [('shared_folder_id', MountFolderArg._shared_folder_id_validator)] MountFolderError._access_error_validator = SharedFolderAccessError_validator MountFolderError._inside_shared_folder_validator = bv.Void() MountFolderError._insufficient_quota_validator = InsufficientQuotaAmounts_validator MountFolderError._already_mounted_validator = bv.Void() MountFolderError._no_permission_validator = bv.Void() MountFolderError._not_mountable_validator = bv.Void() MountFolderError._other_validator = bv.Void() MountFolderError._tagmap = { 'access_error': MountFolderError._access_error_validator, 'inside_shared_folder': MountFolderError._inside_shared_folder_validator, 'insufficient_quota': MountFolderError._insufficient_quota_validator, 'already_mounted': MountFolderError._already_mounted_validator, 'no_permission': MountFolderError._no_permission_validator, 'not_mountable': MountFolderError._not_mountable_validator, 'other': MountFolderError._other_validator, } MountFolderError.inside_shared_folder = MountFolderError('inside_shared_folder') MountFolderError.already_mounted = MountFolderError('already_mounted') MountFolderError.no_permission = MountFolderError('no_permission') MountFolderError.not_mountable = MountFolderError('not_mountable') MountFolderError.other = MountFolderError('other') ParentFolderAccessInfo._folder_name_validator = bv.String() ParentFolderAccessInfo._shared_folder_id_validator = common.SharedFolderId_validator ParentFolderAccessInfo._permissions_validator = bv.List(MemberPermission_validator) ParentFolderAccessInfo._path_validator = bv.String() ParentFolderAccessInfo._all_field_names_ = set([ 'folder_name', 'shared_folder_id', 'permissions', 'path', ]) ParentFolderAccessInfo._all_fields_ = [ ('folder_name', ParentFolderAccessInfo._folder_name_validator), ('shared_folder_id', ParentFolderAccessInfo._shared_folder_id_validator), ('permissions', ParentFolderAccessInfo._permissions_validator), ('path', ParentFolderAccessInfo._path_validator), ] PathLinkMetadata._path_validator = bv.String() PathLinkMetadata._field_names_ = set(['path']) PathLinkMetadata._all_field_names_ = LinkMetadata._all_field_names_.union(PathLinkMetadata._field_names_) PathLinkMetadata._fields_ = [('path', PathLinkMetadata._path_validator)] PathLinkMetadata._all_fields_ = LinkMetadata._all_fields_ + PathLinkMetadata._fields_ PendingUploadMode._file_validator = bv.Void() PendingUploadMode._folder_validator = bv.Void() PendingUploadMode._tagmap = { 'file': PendingUploadMode._file_validator, 'folder': PendingUploadMode._folder_validator, } PendingUploadMode.file = PendingUploadMode('file') PendingUploadMode.folder = PendingUploadMode('folder') PermissionDeniedReason._user_not_same_team_as_owner_validator = bv.Void() PermissionDeniedReason._user_not_allowed_by_owner_validator = bv.Void() PermissionDeniedReason._target_is_indirect_member_validator = bv.Void() PermissionDeniedReason._target_is_owner_validator = bv.Void() PermissionDeniedReason._target_is_self_validator = bv.Void() PermissionDeniedReason._target_not_active_validator = bv.Void() PermissionDeniedReason._folder_is_limited_team_folder_validator = bv.Void() PermissionDeniedReason._owner_not_on_team_validator = bv.Void() PermissionDeniedReason._permission_denied_validator = bv.Void() PermissionDeniedReason._restricted_by_team_validator = bv.Void() PermissionDeniedReason._user_account_type_validator = bv.Void() PermissionDeniedReason._user_not_on_team_validator = bv.Void() PermissionDeniedReason._folder_is_inside_shared_folder_validator = bv.Void() PermissionDeniedReason._restricted_by_parent_folder_validator = bv.Void() PermissionDeniedReason._insufficient_plan_validator = InsufficientPlan_validator PermissionDeniedReason._other_validator = bv.Void() PermissionDeniedReason._tagmap = { 'user_not_same_team_as_owner': PermissionDeniedReason._user_not_same_team_as_owner_validator, 'user_not_allowed_by_owner': PermissionDeniedReason._user_not_allowed_by_owner_validator, 'target_is_indirect_member': PermissionDeniedReason._target_is_indirect_member_validator, 'target_is_owner': PermissionDeniedReason._target_is_owner_validator, 'target_is_self': PermissionDeniedReason._target_is_self_validator, 'target_not_active': PermissionDeniedReason._target_not_active_validator, 'folder_is_limited_team_folder': PermissionDeniedReason._folder_is_limited_team_folder_validator, 'owner_not_on_team': PermissionDeniedReason._owner_not_on_team_validator, 'permission_denied': PermissionDeniedReason._permission_denied_validator, 'restricted_by_team': PermissionDeniedReason._restricted_by_team_validator, 'user_account_type': PermissionDeniedReason._user_account_type_validator, 'user_not_on_team': PermissionDeniedReason._user_not_on_team_validator, 'folder_is_inside_shared_folder': PermissionDeniedReason._folder_is_inside_shared_folder_validator, 'restricted_by_parent_folder': PermissionDeniedReason._restricted_by_parent_folder_validator, 'insufficient_plan': PermissionDeniedReason._insufficient_plan_validator, 'other': PermissionDeniedReason._other_validator, } PermissionDeniedReason.user_not_same_team_as_owner = PermissionDeniedReason('user_not_same_team_as_owner') PermissionDeniedReason.user_not_allowed_by_owner = PermissionDeniedReason('user_not_allowed_by_owner') PermissionDeniedReason.target_is_indirect_member = PermissionDeniedReason('target_is_indirect_member') PermissionDeniedReason.target_is_owner = PermissionDeniedReason('target_is_owner') PermissionDeniedReason.target_is_self = PermissionDeniedReason('target_is_self') PermissionDeniedReason.target_not_active = PermissionDeniedReason('target_not_active') PermissionDeniedReason.folder_is_limited_team_folder = PermissionDeniedReason('folder_is_limited_team_folder') PermissionDeniedReason.owner_not_on_team = PermissionDeniedReason('owner_not_on_team') PermissionDeniedReason.permission_denied = PermissionDeniedReason('permission_denied') PermissionDeniedReason.restricted_by_team = PermissionDeniedReason('restricted_by_team') PermissionDeniedReason.user_account_type = PermissionDeniedReason('user_account_type') PermissionDeniedReason.user_not_on_team = PermissionDeniedReason('user_not_on_team') PermissionDeniedReason.folder_is_inside_shared_folder = PermissionDeniedReason('folder_is_inside_shared_folder') PermissionDeniedReason.restricted_by_parent_folder = PermissionDeniedReason('restricted_by_parent_folder') PermissionDeniedReason.other = PermissionDeniedReason('other') RelinquishFileMembershipArg._file_validator = PathOrId_validator RelinquishFileMembershipArg._all_field_names_ = set(['file']) RelinquishFileMembershipArg._all_fields_ = [('file', RelinquishFileMembershipArg._file_validator)] RelinquishFileMembershipError._access_error_validator = SharingFileAccessError_validator RelinquishFileMembershipError._group_access_validator = bv.Void() RelinquishFileMembershipError._no_permission_validator = bv.Void() RelinquishFileMembershipError._other_validator = bv.Void() RelinquishFileMembershipError._tagmap = { 'access_error': RelinquishFileMembershipError._access_error_validator, 'group_access': RelinquishFileMembershipError._group_access_validator, 'no_permission': RelinquishFileMembershipError._no_permission_validator, 'other': RelinquishFileMembershipError._other_validator, } RelinquishFileMembershipError.group_access = RelinquishFileMembershipError('group_access') RelinquishFileMembershipError.no_permission = RelinquishFileMembershipError('no_permission') RelinquishFileMembershipError.other = RelinquishFileMembershipError('other') RelinquishFolderMembershipArg._shared_folder_id_validator = common.SharedFolderId_validator RelinquishFolderMembershipArg._leave_a_copy_validator = bv.Boolean() RelinquishFolderMembershipArg._all_field_names_ = set([ 'shared_folder_id', 'leave_a_copy', ]) RelinquishFolderMembershipArg._all_fields_ = [ ('shared_folder_id', RelinquishFolderMembershipArg._shared_folder_id_validator), ('leave_a_copy', RelinquishFolderMembershipArg._leave_a_copy_validator), ] RelinquishFolderMembershipError._access_error_validator = SharedFolderAccessError_validator RelinquishFolderMembershipError._folder_owner_validator = bv.Void() RelinquishFolderMembershipError._mounted_validator = bv.Void() RelinquishFolderMembershipError._group_access_validator = bv.Void() RelinquishFolderMembershipError._team_folder_validator = bv.Void() RelinquishFolderMembershipError._no_permission_validator = bv.Void() RelinquishFolderMembershipError._no_explicit_access_validator = bv.Void() RelinquishFolderMembershipError._other_validator = bv.Void() RelinquishFolderMembershipError._tagmap = { 'access_error': RelinquishFolderMembershipError._access_error_validator, 'folder_owner': RelinquishFolderMembershipError._folder_owner_validator, 'mounted': RelinquishFolderMembershipError._mounted_validator, 'group_access': RelinquishFolderMembershipError._group_access_validator, 'team_folder': RelinquishFolderMembershipError._team_folder_validator, 'no_permission': RelinquishFolderMembershipError._no_permission_validator, 'no_explicit_access': RelinquishFolderMembershipError._no_explicit_access_validator, 'other': RelinquishFolderMembershipError._other_validator, } RelinquishFolderMembershipError.folder_owner = RelinquishFolderMembershipError('folder_owner') RelinquishFolderMembershipError.mounted = RelinquishFolderMembershipError('mounted') RelinquishFolderMembershipError.group_access = RelinquishFolderMembershipError('group_access') RelinquishFolderMembershipError.team_folder = RelinquishFolderMembershipError('team_folder') RelinquishFolderMembershipError.no_permission = RelinquishFolderMembershipError('no_permission') RelinquishFolderMembershipError.no_explicit_access = RelinquishFolderMembershipError('no_explicit_access') RelinquishFolderMembershipError.other = RelinquishFolderMembershipError('other') RemoveFileMemberArg._file_validator = PathOrId_validator RemoveFileMemberArg._member_validator = MemberSelector_validator RemoveFileMemberArg._all_field_names_ = set([ 'file', 'member', ]) RemoveFileMemberArg._all_fields_ = [ ('file', RemoveFileMemberArg._file_validator), ('member', RemoveFileMemberArg._member_validator), ] RemoveFileMemberError._user_error_validator = SharingUserError_validator RemoveFileMemberError._access_error_validator = SharingFileAccessError_validator RemoveFileMemberError._no_explicit_access_validator = MemberAccessLevelResult_validator RemoveFileMemberError._other_validator = bv.Void() RemoveFileMemberError._tagmap = { 'user_error': RemoveFileMemberError._user_error_validator, 'access_error': RemoveFileMemberError._access_error_validator, 'no_explicit_access': RemoveFileMemberError._no_explicit_access_validator, 'other': RemoveFileMemberError._other_validator, } RemoveFileMemberError.other = RemoveFileMemberError('other') RemoveFolderMemberArg._shared_folder_id_validator = common.SharedFolderId_validator RemoveFolderMemberArg._member_validator = MemberSelector_validator RemoveFolderMemberArg._leave_a_copy_validator = bv.Boolean() RemoveFolderMemberArg._all_field_names_ = set([ 'shared_folder_id', 'member', 'leave_a_copy', ]) RemoveFolderMemberArg._all_fields_ = [ ('shared_folder_id', RemoveFolderMemberArg._shared_folder_id_validator), ('member', RemoveFolderMemberArg._member_validator), ('leave_a_copy', RemoveFolderMemberArg._leave_a_copy_validator), ] RemoveFolderMemberError._access_error_validator = SharedFolderAccessError_validator RemoveFolderMemberError._member_error_validator = SharedFolderMemberError_validator RemoveFolderMemberError._folder_owner_validator = bv.Void() RemoveFolderMemberError._group_access_validator = bv.Void() RemoveFolderMemberError._team_folder_validator = bv.Void() RemoveFolderMemberError._no_permission_validator = bv.Void() RemoveFolderMemberError._other_validator = bv.Void() RemoveFolderMemberError._tagmap = { 'access_error': RemoveFolderMemberError._access_error_validator, 'member_error': RemoveFolderMemberError._member_error_validator, 'folder_owner': RemoveFolderMemberError._folder_owner_validator, 'group_access': RemoveFolderMemberError._group_access_validator, 'team_folder': RemoveFolderMemberError._team_folder_validator, 'no_permission': RemoveFolderMemberError._no_permission_validator, 'other': RemoveFolderMemberError._other_validator, } RemoveFolderMemberError.folder_owner = RemoveFolderMemberError('folder_owner') RemoveFolderMemberError.group_access = RemoveFolderMemberError('group_access') RemoveFolderMemberError.team_folder = RemoveFolderMemberError('team_folder') RemoveFolderMemberError.no_permission = RemoveFolderMemberError('no_permission') RemoveFolderMemberError.other = RemoveFolderMemberError('other') RemoveMemberJobStatus._complete_validator = MemberAccessLevelResult_validator RemoveMemberJobStatus._failed_validator = RemoveFolderMemberError_validator RemoveMemberJobStatus._tagmap = { 'complete': RemoveMemberJobStatus._complete_validator, 'failed': RemoveMemberJobStatus._failed_validator, } RemoveMemberJobStatus._tagmap.update(async.PollResultBase._tagmap) RequestedVisibility._public_validator = bv.Void() RequestedVisibility._team_only_validator = bv.Void() RequestedVisibility._password_validator = bv.Void() RequestedVisibility._tagmap = { 'public': RequestedVisibility._public_validator, 'team_only': RequestedVisibility._team_only_validator, 'password': RequestedVisibility._password_validator, } RequestedVisibility.public = RequestedVisibility('public') RequestedVisibility.team_only = RequestedVisibility('team_only') RequestedVisibility.password = RequestedVisibility('password') ResolvedVisibility._team_and_password_validator = bv.Void() ResolvedVisibility._shared_folder_only_validator = bv.Void() ResolvedVisibility._other_validator = bv.Void() ResolvedVisibility._tagmap = { 'team_and_password': ResolvedVisibility._team_and_password_validator, 'shared_folder_only': ResolvedVisibility._shared_folder_only_validator, 'other': ResolvedVisibility._other_validator, } ResolvedVisibility._tagmap.update(RequestedVisibility._tagmap) ResolvedVisibility.team_and_password = ResolvedVisibility('team_and_password') ResolvedVisibility.shared_folder_only = ResolvedVisibility('shared_folder_only') ResolvedVisibility.other = ResolvedVisibility('other') RevokeSharedLinkArg._url_validator = bv.String() RevokeSharedLinkArg._all_field_names_ = set(['url']) RevokeSharedLinkArg._all_fields_ = [('url', RevokeSharedLinkArg._url_validator)] RevokeSharedLinkError._shared_link_malformed_validator = bv.Void() RevokeSharedLinkError._tagmap = { 'shared_link_malformed': RevokeSharedLinkError._shared_link_malformed_validator, } RevokeSharedLinkError._tagmap.update(SharedLinkError._tagmap) RevokeSharedLinkError.shared_link_malformed = RevokeSharedLinkError('shared_link_malformed') ShareFolderArgBase._acl_update_policy_validator = bv.Nullable(AclUpdatePolicy_validator) ShareFolderArgBase._force_async_validator = bv.Boolean() ShareFolderArgBase._member_policy_validator = bv.Nullable(MemberPolicy_validator) ShareFolderArgBase._path_validator = files.WritePath_validator ShareFolderArgBase._shared_link_policy_validator = bv.Nullable(SharedLinkPolicy_validator) ShareFolderArgBase._viewer_info_policy_validator = bv.Nullable(ViewerInfoPolicy_validator) ShareFolderArgBase._all_field_names_ = set([ 'acl_update_policy', 'force_async', 'member_policy', 'path', 'shared_link_policy', 'viewer_info_policy', ]) ShareFolderArgBase._all_fields_ = [ ('acl_update_policy', ShareFolderArgBase._acl_update_policy_validator), ('force_async', ShareFolderArgBase._force_async_validator), ('member_policy', ShareFolderArgBase._member_policy_validator), ('path', ShareFolderArgBase._path_validator), ('shared_link_policy', ShareFolderArgBase._shared_link_policy_validator), ('viewer_info_policy', ShareFolderArgBase._viewer_info_policy_validator), ] ShareFolderArg._actions_validator = bv.Nullable(bv.List(FolderAction_validator)) ShareFolderArg._link_settings_validator = bv.Nullable(LinkSettings_validator) ShareFolderArg._all_field_names_ = ShareFolderArgBase._all_field_names_.union(set([ 'actions', 'link_settings', ])) ShareFolderArg._all_fields_ = ShareFolderArgBase._all_fields_ + [ ('actions', ShareFolderArg._actions_validator), ('link_settings', ShareFolderArg._link_settings_validator), ] ShareFolderErrorBase._email_unverified_validator = bv.Void() ShareFolderErrorBase._bad_path_validator = SharePathError_validator ShareFolderErrorBase._team_policy_disallows_member_policy_validator = bv.Void() ShareFolderErrorBase._disallowed_shared_link_policy_validator = bv.Void() ShareFolderErrorBase._other_validator = bv.Void() ShareFolderErrorBase._tagmap = { 'email_unverified': ShareFolderErrorBase._email_unverified_validator, 'bad_path': ShareFolderErrorBase._bad_path_validator, 'team_policy_disallows_member_policy': ShareFolderErrorBase._team_policy_disallows_member_policy_validator, 'disallowed_shared_link_policy': ShareFolderErrorBase._disallowed_shared_link_policy_validator, 'other': ShareFolderErrorBase._other_validator, } ShareFolderErrorBase.email_unverified = ShareFolderErrorBase('email_unverified') ShareFolderErrorBase.team_policy_disallows_member_policy = ShareFolderErrorBase('team_policy_disallows_member_policy') ShareFolderErrorBase.disallowed_shared_link_policy = ShareFolderErrorBase('disallowed_shared_link_policy') ShareFolderErrorBase.other = ShareFolderErrorBase('other') ShareFolderError._no_permission_validator = bv.Void() ShareFolderError._tagmap = { 'no_permission': ShareFolderError._no_permission_validator, } ShareFolderError._tagmap.update(ShareFolderErrorBase._tagmap) ShareFolderError.no_permission = ShareFolderError('no_permission') ShareFolderJobStatus._complete_validator = SharedFolderMetadata_validator ShareFolderJobStatus._failed_validator = ShareFolderError_validator ShareFolderJobStatus._tagmap = { 'complete': ShareFolderJobStatus._complete_validator, 'failed': ShareFolderJobStatus._failed_validator, } ShareFolderJobStatus._tagmap.update(async.PollResultBase._tagmap) ShareFolderLaunch._complete_validator = SharedFolderMetadata_validator ShareFolderLaunch._tagmap = { 'complete': ShareFolderLaunch._complete_validator, } ShareFolderLaunch._tagmap.update(async.LaunchResultBase._tagmap) SharePathError._is_file_validator = bv.Void() SharePathError._inside_shared_folder_validator = bv.Void() SharePathError._contains_shared_folder_validator = bv.Void() SharePathError._contains_app_folder_validator = bv.Void() SharePathError._contains_team_folder_validator = bv.Void() SharePathError._is_app_folder_validator = bv.Void() SharePathError._inside_app_folder_validator = bv.Void() SharePathError._is_public_folder_validator = bv.Void() SharePathError._inside_public_folder_validator = bv.Void() SharePathError._already_shared_validator = SharedFolderMetadata_validator SharePathError._invalid_path_validator = bv.Void() SharePathError._is_osx_package_validator = bv.Void() SharePathError._inside_osx_package_validator = bv.Void() SharePathError._other_validator = bv.Void() SharePathError._tagmap = { 'is_file': SharePathError._is_file_validator, 'inside_shared_folder': SharePathError._inside_shared_folder_validator, 'contains_shared_folder': SharePathError._contains_shared_folder_validator, 'contains_app_folder': SharePathError._contains_app_folder_validator, 'contains_team_folder': SharePathError._contains_team_folder_validator, 'is_app_folder': SharePathError._is_app_folder_validator, 'inside_app_folder': SharePathError._inside_app_folder_validator, 'is_public_folder': SharePathError._is_public_folder_validator, 'inside_public_folder': SharePathError._inside_public_folder_validator, 'already_shared': SharePathError._already_shared_validator, 'invalid_path': SharePathError._invalid_path_validator, 'is_osx_package': SharePathError._is_osx_package_validator, 'inside_osx_package': SharePathError._inside_osx_package_validator, 'other': SharePathError._other_validator, } SharePathError.is_file = SharePathError('is_file') SharePathError.inside_shared_folder = SharePathError('inside_shared_folder') SharePathError.contains_shared_folder = SharePathError('contains_shared_folder') SharePathError.contains_app_folder = SharePathError('contains_app_folder') SharePathError.contains_team_folder = SharePathError('contains_team_folder') SharePathError.is_app_folder = SharePathError('is_app_folder') SharePathError.inside_app_folder = SharePathError('inside_app_folder') SharePathError.is_public_folder = SharePathError('is_public_folder') SharePathError.inside_public_folder = SharePathError('inside_public_folder') SharePathError.invalid_path = SharePathError('invalid_path') SharePathError.is_osx_package = SharePathError('is_osx_package') SharePathError.inside_osx_package = SharePathError('inside_osx_package') SharePathError.other = SharePathError('other') SharedContentLinkMetadata._audience_exceptions_validator = bv.Nullable(AudienceExceptions_validator) SharedContentLinkMetadata._url_validator = bv.String() SharedContentLinkMetadata._all_field_names_ = SharedContentLinkMetadataBase._all_field_names_.union(set([ 'audience_exceptions', 'url', ])) SharedContentLinkMetadata._all_fields_ = SharedContentLinkMetadataBase._all_fields_ + [ ('audience_exceptions', SharedContentLinkMetadata._audience_exceptions_validator), ('url', SharedContentLinkMetadata._url_validator), ] SharedFileMembers._users_validator = bv.List(UserFileMembershipInfo_validator) SharedFileMembers._groups_validator = bv.List(GroupMembershipInfo_validator) SharedFileMembers._invitees_validator = bv.List(InviteeMembershipInfo_validator) SharedFileMembers._cursor_validator = bv.Nullable(bv.String()) SharedFileMembers._all_field_names_ = set([ 'users', 'groups', 'invitees', 'cursor', ]) SharedFileMembers._all_fields_ = [ ('users', SharedFileMembers._users_validator), ('groups', SharedFileMembers._groups_validator), ('invitees', SharedFileMembers._invitees_validator), ('cursor', SharedFileMembers._cursor_validator), ] SharedFileMetadata._access_type_validator = bv.Nullable(AccessLevel_validator) SharedFileMetadata._id_validator = FileId_validator SharedFileMetadata._expected_link_metadata_validator = bv.Nullable(ExpectedSharedContentLinkMetadata_validator) SharedFileMetadata._link_metadata_validator = bv.Nullable(SharedContentLinkMetadata_validator) SharedFileMetadata._name_validator = bv.String() SharedFileMetadata._owner_display_names_validator = bv.Nullable(bv.List(bv.String())) SharedFileMetadata._owner_team_validator = bv.Nullable(users.Team_validator) SharedFileMetadata._parent_shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator) SharedFileMetadata._path_display_validator = bv.Nullable(bv.String()) SharedFileMetadata._path_lower_validator = bv.Nullable(bv.String()) SharedFileMetadata._permissions_validator = bv.Nullable(bv.List(FilePermission_validator)) SharedFileMetadata._policy_validator = FolderPolicy_validator SharedFileMetadata._preview_url_validator = bv.String() SharedFileMetadata._time_invited_validator = bv.Nullable(common.DropboxTimestamp_validator) SharedFileMetadata._all_field_names_ = set([ 'access_type', 'id', 'expected_link_metadata', 'link_metadata', 'name', 'owner_display_names', 'owner_team', 'parent_shared_folder_id', 'path_display', 'path_lower', 'permissions', 'policy', 'preview_url', 'time_invited', ]) SharedFileMetadata._all_fields_ = [ ('access_type', SharedFileMetadata._access_type_validator), ('id', SharedFileMetadata._id_validator), ('expected_link_metadata', SharedFileMetadata._expected_link_metadata_validator), ('link_metadata', SharedFileMetadata._link_metadata_validator), ('name', SharedFileMetadata._name_validator), ('owner_display_names', SharedFileMetadata._owner_display_names_validator), ('owner_team', SharedFileMetadata._owner_team_validator), ('parent_shared_folder_id', SharedFileMetadata._parent_shared_folder_id_validator), ('path_display', SharedFileMetadata._path_display_validator), ('path_lower', SharedFileMetadata._path_lower_validator), ('permissions', SharedFileMetadata._permissions_validator), ('policy', SharedFileMetadata._policy_validator), ('preview_url', SharedFileMetadata._preview_url_validator), ('time_invited', SharedFileMetadata._time_invited_validator), ] SharedFolderAccessError._invalid_id_validator = bv.Void() SharedFolderAccessError._not_a_member_validator = bv.Void() SharedFolderAccessError._email_unverified_validator = bv.Void() SharedFolderAccessError._unmounted_validator = bv.Void() SharedFolderAccessError._other_validator = bv.Void() SharedFolderAccessError._tagmap = { 'invalid_id': SharedFolderAccessError._invalid_id_validator, 'not_a_member': SharedFolderAccessError._not_a_member_validator, 'email_unverified': SharedFolderAccessError._email_unverified_validator, 'unmounted': SharedFolderAccessError._unmounted_validator, 'other': SharedFolderAccessError._other_validator, } SharedFolderAccessError.invalid_id = SharedFolderAccessError('invalid_id') SharedFolderAccessError.not_a_member = SharedFolderAccessError('not_a_member') SharedFolderAccessError.email_unverified = SharedFolderAccessError('email_unverified') SharedFolderAccessError.unmounted = SharedFolderAccessError('unmounted') SharedFolderAccessError.other = SharedFolderAccessError('other') SharedFolderMemberError._invalid_dropbox_id_validator = bv.Void() SharedFolderMemberError._not_a_member_validator = bv.Void() SharedFolderMemberError._no_explicit_access_validator = MemberAccessLevelResult_validator SharedFolderMemberError._other_validator = bv.Void() SharedFolderMemberError._tagmap = { 'invalid_dropbox_id': SharedFolderMemberError._invalid_dropbox_id_validator, 'not_a_member': SharedFolderMemberError._not_a_member_validator, 'no_explicit_access': SharedFolderMemberError._no_explicit_access_validator, 'other': SharedFolderMemberError._other_validator, } SharedFolderMemberError.invalid_dropbox_id = SharedFolderMemberError('invalid_dropbox_id') SharedFolderMemberError.not_a_member = SharedFolderMemberError('not_a_member') SharedFolderMemberError.other = SharedFolderMemberError('other') SharedFolderMembers._users_validator = bv.List(UserMembershipInfo_validator) SharedFolderMembers._groups_validator = bv.List(GroupMembershipInfo_validator) SharedFolderMembers._invitees_validator = bv.List(InviteeMembershipInfo_validator) SharedFolderMembers._cursor_validator = bv.Nullable(bv.String()) SharedFolderMembers._all_field_names_ = set([ 'users', 'groups', 'invitees', 'cursor', ]) SharedFolderMembers._all_fields_ = [ ('users', SharedFolderMembers._users_validator), ('groups', SharedFolderMembers._groups_validator), ('invitees', SharedFolderMembers._invitees_validator), ('cursor', SharedFolderMembers._cursor_validator), ] SharedFolderMetadataBase._access_type_validator = AccessLevel_validator SharedFolderMetadataBase._is_inside_team_folder_validator = bv.Boolean() SharedFolderMetadataBase._is_team_folder_validator = bv.Boolean() SharedFolderMetadataBase._owner_display_names_validator = bv.Nullable(bv.List(bv.String())) SharedFolderMetadataBase._owner_team_validator = bv.Nullable(users.Team_validator) SharedFolderMetadataBase._parent_shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator) SharedFolderMetadataBase._path_lower_validator = bv.Nullable(bv.String()) SharedFolderMetadataBase._all_field_names_ = set([ 'access_type', 'is_inside_team_folder', 'is_team_folder', 'owner_display_names', 'owner_team', 'parent_shared_folder_id', 'path_lower', ]) SharedFolderMetadataBase._all_fields_ = [ ('access_type', SharedFolderMetadataBase._access_type_validator), ('is_inside_team_folder', SharedFolderMetadataBase._is_inside_team_folder_validator), ('is_team_folder', SharedFolderMetadataBase._is_team_folder_validator), ('owner_display_names', SharedFolderMetadataBase._owner_display_names_validator), ('owner_team', SharedFolderMetadataBase._owner_team_validator), ('parent_shared_folder_id', SharedFolderMetadataBase._parent_shared_folder_id_validator), ('path_lower', SharedFolderMetadataBase._path_lower_validator), ] SharedFolderMetadata._link_metadata_validator = bv.Nullable(SharedContentLinkMetadata_validator) SharedFolderMetadata._name_validator = bv.String() SharedFolderMetadata._permissions_validator = bv.Nullable(bv.List(FolderPermission_validator)) SharedFolderMetadata._policy_validator = FolderPolicy_validator SharedFolderMetadata._preview_url_validator = bv.String() SharedFolderMetadata._shared_folder_id_validator = common.SharedFolderId_validator SharedFolderMetadata._time_invited_validator = common.DropboxTimestamp_validator SharedFolderMetadata._all_field_names_ = SharedFolderMetadataBase._all_field_names_.union(set([ 'link_metadata', 'name', 'permissions', 'policy', 'preview_url', 'shared_folder_id', 'time_invited', ])) SharedFolderMetadata._all_fields_ = SharedFolderMetadataBase._all_fields_ + [ ('link_metadata', SharedFolderMetadata._link_metadata_validator), ('name', SharedFolderMetadata._name_validator), ('permissions', SharedFolderMetadata._permissions_validator), ('policy', SharedFolderMetadata._policy_validator), ('preview_url', SharedFolderMetadata._preview_url_validator), ('shared_folder_id', SharedFolderMetadata._shared_folder_id_validator), ('time_invited', SharedFolderMetadata._time_invited_validator), ] SharedLinkAccessFailureReason._login_required_validator = bv.Void() SharedLinkAccessFailureReason._email_verify_required_validator = bv.Void() SharedLinkAccessFailureReason._password_required_validator = bv.Void() SharedLinkAccessFailureReason._team_only_validator = bv.Void() SharedLinkAccessFailureReason._owner_only_validator = bv.Void() SharedLinkAccessFailureReason._other_validator = bv.Void() SharedLinkAccessFailureReason._tagmap = { 'login_required': SharedLinkAccessFailureReason._login_required_validator, 'email_verify_required': SharedLinkAccessFailureReason._email_verify_required_validator, 'password_required': SharedLinkAccessFailureReason._password_required_validator, 'team_only': SharedLinkAccessFailureReason._team_only_validator, 'owner_only': SharedLinkAccessFailureReason._owner_only_validator, 'other': SharedLinkAccessFailureReason._other_validator, } SharedLinkAccessFailureReason.login_required = SharedLinkAccessFailureReason('login_required') SharedLinkAccessFailureReason.email_verify_required = SharedLinkAccessFailureReason('email_verify_required') SharedLinkAccessFailureReason.password_required = SharedLinkAccessFailureReason('password_required') SharedLinkAccessFailureReason.team_only = SharedLinkAccessFailureReason('team_only') SharedLinkAccessFailureReason.owner_only = SharedLinkAccessFailureReason('owner_only') SharedLinkAccessFailureReason.other = SharedLinkAccessFailureReason('other') SharedLinkPolicy._anyone_validator = bv.Void() SharedLinkPolicy._team_validator = bv.Void() SharedLinkPolicy._members_validator = bv.Void() SharedLinkPolicy._other_validator = bv.Void() SharedLinkPolicy._tagmap = { 'anyone': SharedLinkPolicy._anyone_validator, 'team': SharedLinkPolicy._team_validator, 'members': SharedLinkPolicy._members_validator, 'other': SharedLinkPolicy._other_validator, } SharedLinkPolicy.anyone = SharedLinkPolicy('anyone') SharedLinkPolicy.team = SharedLinkPolicy('team') SharedLinkPolicy.members = SharedLinkPolicy('members') SharedLinkPolicy.other = SharedLinkPolicy('other') SharedLinkSettings._requested_visibility_validator = bv.Nullable(RequestedVisibility_validator) SharedLinkSettings._link_password_validator = bv.Nullable(bv.String()) SharedLinkSettings._expires_validator = bv.Nullable(common.DropboxTimestamp_validator) SharedLinkSettings._all_field_names_ = set([ 'requested_visibility', 'link_password', 'expires', ]) SharedLinkSettings._all_fields_ = [ ('requested_visibility', SharedLinkSettings._requested_visibility_validator), ('link_password', SharedLinkSettings._link_password_validator), ('expires', SharedLinkSettings._expires_validator), ] SharedLinkSettingsError._invalid_settings_validator = bv.Void() SharedLinkSettingsError._not_authorized_validator = bv.Void() SharedLinkSettingsError._tagmap = { 'invalid_settings': SharedLinkSettingsError._invalid_settings_validator, 'not_authorized': SharedLinkSettingsError._not_authorized_validator, } SharedLinkSettingsError.invalid_settings = SharedLinkSettingsError('invalid_settings') SharedLinkSettingsError.not_authorized = SharedLinkSettingsError('not_authorized') SharingFileAccessError._no_permission_validator = bv.Void() SharingFileAccessError._invalid_file_validator = bv.Void() SharingFileAccessError._is_folder_validator = bv.Void() SharingFileAccessError._inside_public_folder_validator = bv.Void() SharingFileAccessError._inside_osx_package_validator = bv.Void() SharingFileAccessError._other_validator = bv.Void() SharingFileAccessError._tagmap = { 'no_permission': SharingFileAccessError._no_permission_validator, 'invalid_file': SharingFileAccessError._invalid_file_validator, 'is_folder': SharingFileAccessError._is_folder_validator, 'inside_public_folder': SharingFileAccessError._inside_public_folder_validator, 'inside_osx_package': SharingFileAccessError._inside_osx_package_validator, 'other': SharingFileAccessError._other_validator, } SharingFileAccessError.no_permission = SharingFileAccessError('no_permission') SharingFileAccessError.invalid_file = SharingFileAccessError('invalid_file') SharingFileAccessError.is_folder = SharingFileAccessError('is_folder') SharingFileAccessError.inside_public_folder = SharingFileAccessError('inside_public_folder') SharingFileAccessError.inside_osx_package = SharingFileAccessError('inside_osx_package') SharingFileAccessError.other = SharingFileAccessError('other') SharingUserError._email_unverified_validator = bv.Void() SharingUserError._other_validator = bv.Void() SharingUserError._tagmap = { 'email_unverified': SharingUserError._email_unverified_validator, 'other': SharingUserError._other_validator, } SharingUserError.email_unverified = SharingUserError('email_unverified') SharingUserError.other = SharingUserError('other') TeamMemberInfo._team_info_validator = TeamInfo_validator TeamMemberInfo._display_name_validator = bv.String() TeamMemberInfo._member_id_validator = bv.Nullable(bv.String()) TeamMemberInfo._all_field_names_ = set([ 'team_info', 'display_name', 'member_id', ]) TeamMemberInfo._all_fields_ = [ ('team_info', TeamMemberInfo._team_info_validator), ('display_name', TeamMemberInfo._display_name_validator), ('member_id', TeamMemberInfo._member_id_validator), ] TransferFolderArg._shared_folder_id_validator = common.SharedFolderId_validator TransferFolderArg._to_dropbox_id_validator = DropboxId_validator TransferFolderArg._all_field_names_ = set([ 'shared_folder_id', 'to_dropbox_id', ]) TransferFolderArg._all_fields_ = [ ('shared_folder_id', TransferFolderArg._shared_folder_id_validator), ('to_dropbox_id', TransferFolderArg._to_dropbox_id_validator), ] TransferFolderError._access_error_validator = SharedFolderAccessError_validator TransferFolderError._invalid_dropbox_id_validator = bv.Void() TransferFolderError._new_owner_not_a_member_validator = bv.Void() TransferFolderError._new_owner_unmounted_validator = bv.Void() TransferFolderError._new_owner_email_unverified_validator = bv.Void() TransferFolderError._team_folder_validator = bv.Void() TransferFolderError._no_permission_validator = bv.Void() TransferFolderError._other_validator = bv.Void() TransferFolderError._tagmap = { 'access_error': TransferFolderError._access_error_validator, 'invalid_dropbox_id': TransferFolderError._invalid_dropbox_id_validator, 'new_owner_not_a_member': TransferFolderError._new_owner_not_a_member_validator, 'new_owner_unmounted': TransferFolderError._new_owner_unmounted_validator, 'new_owner_email_unverified': TransferFolderError._new_owner_email_unverified_validator, 'team_folder': TransferFolderError._team_folder_validator, 'no_permission': TransferFolderError._no_permission_validator, 'other': TransferFolderError._other_validator, } TransferFolderError.invalid_dropbox_id = TransferFolderError('invalid_dropbox_id') TransferFolderError.new_owner_not_a_member = TransferFolderError('new_owner_not_a_member') TransferFolderError.new_owner_unmounted = TransferFolderError('new_owner_unmounted') TransferFolderError.new_owner_email_unverified = TransferFolderError('new_owner_email_unverified') TransferFolderError.team_folder = TransferFolderError('team_folder') TransferFolderError.no_permission = TransferFolderError('no_permission') TransferFolderError.other = TransferFolderError('other') UnmountFolderArg._shared_folder_id_validator = common.SharedFolderId_validator UnmountFolderArg._all_field_names_ = set(['shared_folder_id']) UnmountFolderArg._all_fields_ = [('shared_folder_id', UnmountFolderArg._shared_folder_id_validator)] UnmountFolderError._access_error_validator = SharedFolderAccessError_validator UnmountFolderError._no_permission_validator = bv.Void() UnmountFolderError._not_unmountable_validator = bv.Void() UnmountFolderError._other_validator = bv.Void() UnmountFolderError._tagmap = { 'access_error': UnmountFolderError._access_error_validator, 'no_permission': UnmountFolderError._no_permission_validator, 'not_unmountable': UnmountFolderError._not_unmountable_validator, 'other': UnmountFolderError._other_validator, } UnmountFolderError.no_permission = UnmountFolderError('no_permission') UnmountFolderError.not_unmountable = UnmountFolderError('not_unmountable') UnmountFolderError.other = UnmountFolderError('other') UnshareFileArg._file_validator = PathOrId_validator UnshareFileArg._all_field_names_ = set(['file']) UnshareFileArg._all_fields_ = [('file', UnshareFileArg._file_validator)] UnshareFileError._user_error_validator = SharingUserError_validator UnshareFileError._access_error_validator = SharingFileAccessError_validator UnshareFileError._other_validator = bv.Void() UnshareFileError._tagmap = { 'user_error': UnshareFileError._user_error_validator, 'access_error': UnshareFileError._access_error_validator, 'other': UnshareFileError._other_validator, } UnshareFileError.other = UnshareFileError('other') UnshareFolderArg._shared_folder_id_validator = common.SharedFolderId_validator UnshareFolderArg._leave_a_copy_validator = bv.Boolean() UnshareFolderArg._all_field_names_ = set([ 'shared_folder_id', 'leave_a_copy', ]) UnshareFolderArg._all_fields_ = [ ('shared_folder_id', UnshareFolderArg._shared_folder_id_validator), ('leave_a_copy', UnshareFolderArg._leave_a_copy_validator), ] UnshareFolderError._access_error_validator = SharedFolderAccessError_validator UnshareFolderError._team_folder_validator = bv.Void() UnshareFolderError._no_permission_validator = bv.Void() UnshareFolderError._too_many_files_validator = bv.Void() UnshareFolderError._other_validator = bv.Void() UnshareFolderError._tagmap = { 'access_error': UnshareFolderError._access_error_validator, 'team_folder': UnshareFolderError._team_folder_validator, 'no_permission': UnshareFolderError._no_permission_validator, 'too_many_files': UnshareFolderError._too_many_files_validator, 'other': UnshareFolderError._other_validator, } UnshareFolderError.team_folder = UnshareFolderError('team_folder') UnshareFolderError.no_permission = UnshareFolderError('no_permission') UnshareFolderError.too_many_files = UnshareFolderError('too_many_files') UnshareFolderError.other = UnshareFolderError('other') UpdateFileMemberArgs._all_field_names_ = ChangeFileMemberAccessArgs._all_field_names_.union(set([])) UpdateFileMemberArgs._all_fields_ = ChangeFileMemberAccessArgs._all_fields_ + [] UpdateFolderMemberArg._shared_folder_id_validator = common.SharedFolderId_validator UpdateFolderMemberArg._member_validator = MemberSelector_validator UpdateFolderMemberArg._access_level_validator = AccessLevel_validator UpdateFolderMemberArg._all_field_names_ = set([ 'shared_folder_id', 'member', 'access_level', ]) UpdateFolderMemberArg._all_fields_ = [ ('shared_folder_id', UpdateFolderMemberArg._shared_folder_id_validator), ('member', UpdateFolderMemberArg._member_validator), ('access_level', UpdateFolderMemberArg._access_level_validator), ] UpdateFolderMemberError._access_error_validator = SharedFolderAccessError_validator UpdateFolderMemberError._member_error_validator = SharedFolderMemberError_validator UpdateFolderMemberError._no_explicit_access_validator = AddFolderMemberError_validator UpdateFolderMemberError._insufficient_plan_validator = bv.Void() UpdateFolderMemberError._no_permission_validator = bv.Void() UpdateFolderMemberError._other_validator = bv.Void() UpdateFolderMemberError._tagmap = { 'access_error': UpdateFolderMemberError._access_error_validator, 'member_error': UpdateFolderMemberError._member_error_validator, 'no_explicit_access': UpdateFolderMemberError._no_explicit_access_validator, 'insufficient_plan': UpdateFolderMemberError._insufficient_plan_validator, 'no_permission': UpdateFolderMemberError._no_permission_validator, 'other': UpdateFolderMemberError._other_validator, } UpdateFolderMemberError.insufficient_plan = UpdateFolderMemberError('insufficient_plan') UpdateFolderMemberError.no_permission = UpdateFolderMemberError('no_permission') UpdateFolderMemberError.other = UpdateFolderMemberError('other') UpdateFolderPolicyArg._shared_folder_id_validator = common.SharedFolderId_validator UpdateFolderPolicyArg._member_policy_validator = bv.Nullable(MemberPolicy_validator) UpdateFolderPolicyArg._acl_update_policy_validator = bv.Nullable(AclUpdatePolicy_validator) UpdateFolderPolicyArg._viewer_info_policy_validator = bv.Nullable(ViewerInfoPolicy_validator) UpdateFolderPolicyArg._shared_link_policy_validator = bv.Nullable(SharedLinkPolicy_validator) UpdateFolderPolicyArg._link_settings_validator = bv.Nullable(LinkSettings_validator) UpdateFolderPolicyArg._actions_validator = bv.Nullable(bv.List(FolderAction_validator)) UpdateFolderPolicyArg._all_field_names_ = set([ 'shared_folder_id', 'member_policy', 'acl_update_policy', 'viewer_info_policy', 'shared_link_policy', 'link_settings', 'actions', ]) UpdateFolderPolicyArg._all_fields_ = [ ('shared_folder_id', UpdateFolderPolicyArg._shared_folder_id_validator), ('member_policy', UpdateFolderPolicyArg._member_policy_validator), ('acl_update_policy', UpdateFolderPolicyArg._acl_update_policy_validator), ('viewer_info_policy', UpdateFolderPolicyArg._viewer_info_policy_validator), ('shared_link_policy', UpdateFolderPolicyArg._shared_link_policy_validator), ('link_settings', UpdateFolderPolicyArg._link_settings_validator), ('actions', UpdateFolderPolicyArg._actions_validator), ] UpdateFolderPolicyError._access_error_validator = SharedFolderAccessError_validator UpdateFolderPolicyError._not_on_team_validator = bv.Void() UpdateFolderPolicyError._team_policy_disallows_member_policy_validator = bv.Void() UpdateFolderPolicyError._disallowed_shared_link_policy_validator = bv.Void() UpdateFolderPolicyError._no_permission_validator = bv.Void() UpdateFolderPolicyError._team_folder_validator = bv.Void() UpdateFolderPolicyError._other_validator = bv.Void() UpdateFolderPolicyError._tagmap = { 'access_error': UpdateFolderPolicyError._access_error_validator, 'not_on_team': UpdateFolderPolicyError._not_on_team_validator, 'team_policy_disallows_member_policy': UpdateFolderPolicyError._team_policy_disallows_member_policy_validator, 'disallowed_shared_link_policy': UpdateFolderPolicyError._disallowed_shared_link_policy_validator, 'no_permission': UpdateFolderPolicyError._no_permission_validator, 'team_folder': UpdateFolderPolicyError._team_folder_validator, 'other': UpdateFolderPolicyError._other_validator, } UpdateFolderPolicyError.not_on_team = UpdateFolderPolicyError('not_on_team') UpdateFolderPolicyError.team_policy_disallows_member_policy = UpdateFolderPolicyError('team_policy_disallows_member_policy') UpdateFolderPolicyError.disallowed_shared_link_policy = UpdateFolderPolicyError('disallowed_shared_link_policy') UpdateFolderPolicyError.no_permission = UpdateFolderPolicyError('no_permission') UpdateFolderPolicyError.team_folder = UpdateFolderPolicyError('team_folder') UpdateFolderPolicyError.other = UpdateFolderPolicyError('other') UserMembershipInfo._user_validator = UserInfo_validator UserMembershipInfo._all_field_names_ = MembershipInfo._all_field_names_.union(set(['user'])) UserMembershipInfo._all_fields_ = MembershipInfo._all_fields_ + [('user', UserMembershipInfo._user_validator)] UserFileMembershipInfo._time_last_seen_validator = bv.Nullable(common.DropboxTimestamp_validator) UserFileMembershipInfo._all_field_names_ = UserMembershipInfo._all_field_names_.union(set(['time_last_seen'])) UserFileMembershipInfo._all_fields_ = UserMembershipInfo._all_fields_ + [('time_last_seen', UserFileMembershipInfo._time_last_seen_validator)] UserInfo._account_id_validator = users_common.AccountId_validator UserInfo._same_team_validator = bv.Boolean() UserInfo._team_member_id_validator = bv.Nullable(bv.String()) UserInfo._all_field_names_ = set([ 'account_id', 'same_team', 'team_member_id', ]) UserInfo._all_fields_ = [ ('account_id', UserInfo._account_id_validator), ('same_team', UserInfo._same_team_validator), ('team_member_id', UserInfo._team_member_id_validator), ] ViewerInfoPolicy._enabled_validator = bv.Void() ViewerInfoPolicy._disabled_validator = bv.Void() ViewerInfoPolicy._other_validator = bv.Void() ViewerInfoPolicy._tagmap = { 'enabled': ViewerInfoPolicy._enabled_validator, 'disabled': ViewerInfoPolicy._disabled_validator, 'other': ViewerInfoPolicy._other_validator, } ViewerInfoPolicy.enabled = ViewerInfoPolicy('enabled') ViewerInfoPolicy.disabled = ViewerInfoPolicy('disabled') ViewerInfoPolicy.other = ViewerInfoPolicy('other') Visibility._public_validator = bv.Void() Visibility._team_only_validator = bv.Void() Visibility._password_validator = bv.Void() Visibility._team_and_password_validator = bv.Void() Visibility._shared_folder_only_validator = bv.Void() Visibility._other_validator = bv.Void() Visibility._tagmap = { 'public': Visibility._public_validator, 'team_only': Visibility._team_only_validator, 'password': Visibility._password_validator, 'team_and_password': Visibility._team_and_password_validator, 'shared_folder_only': Visibility._shared_folder_only_validator, 'other': Visibility._other_validator, } Visibility.public = Visibility('public') Visibility.team_only = Visibility('team_only') Visibility.password = Visibility('password') Visibility.team_and_password = Visibility('team_and_password') Visibility.shared_folder_only = Visibility('shared_folder_only') Visibility.other = Visibility('other') add_file_member = bb.Route( 'add_file_member', False, AddFileMemberArgs_validator, bv.List(FileMemberActionResult_validator), AddFileMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) add_folder_member = bb.Route( 'add_folder_member', False, AddFolderMemberArg_validator, bv.Void(), AddFolderMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) change_file_member_access = bb.Route( 'change_file_member_access', True, ChangeFileMemberAccessArgs_validator, FileMemberActionResult_validator, FileMemberActionError_validator, {'host': u'api', 'style': u'rpc'}, ) check_job_status = bb.Route( 'check_job_status', False, async.PollArg_validator, JobStatus_validator, async.PollError_validator, {'host': u'api', 'style': u'rpc'}, ) check_remove_member_job_status = bb.Route( 'check_remove_member_job_status', False, async.PollArg_validator, RemoveMemberJobStatus_validator, async.PollError_validator, {'host': u'api', 'style': u'rpc'}, ) check_share_job_status = bb.Route( 'check_share_job_status', False, async.PollArg_validator, ShareFolderJobStatus_validator, async.PollError_validator, {'host': u'api', 'style': u'rpc'}, ) create_shared_link = bb.Route( 'create_shared_link', True, CreateSharedLinkArg_validator, PathLinkMetadata_validator, CreateSharedLinkError_validator, {'host': u'api', 'style': u'rpc'}, ) create_shared_link_with_settings = bb.Route( 'create_shared_link_with_settings', False, CreateSharedLinkWithSettingsArg_validator, SharedLinkMetadata_validator, CreateSharedLinkWithSettingsError_validator, {'host': u'api', 'style': u'rpc'}, ) get_file_metadata = bb.Route( 'get_file_metadata', False, GetFileMetadataArg_validator, SharedFileMetadata_validator, GetFileMetadataError_validator, {'host': u'api', 'style': u'rpc'}, ) get_file_metadata_batch = bb.Route( 'get_file_metadata/batch', False, GetFileMetadataBatchArg_validator, bv.List(GetFileMetadataBatchResult_validator), SharingUserError_validator, {'host': u'api', 'style': u'rpc'}, ) get_folder_metadata = bb.Route( 'get_folder_metadata', False, GetMetadataArgs_validator, SharedFolderMetadata_validator, SharedFolderAccessError_validator, {'host': u'api', 'style': u'rpc'}, ) get_shared_link_file = bb.Route( 'get_shared_link_file', False, GetSharedLinkFileArg_validator, SharedLinkMetadata_validator, GetSharedLinkFileError_validator, {'host': u'content', 'style': u'download'}, ) get_shared_link_metadata = bb.Route( 'get_shared_link_metadata', False, GetSharedLinkMetadataArg_validator, SharedLinkMetadata_validator, SharedLinkError_validator, {'host': u'api', 'style': u'rpc'}, ) get_shared_links = bb.Route( 'get_shared_links', True, GetSharedLinksArg_validator, GetSharedLinksResult_validator, GetSharedLinksError_validator, {'host': u'api', 'style': u'rpc'}, ) list_file_members = bb.Route( 'list_file_members', False, ListFileMembersArg_validator, SharedFileMembers_validator, ListFileMembersError_validator, {'host': u'api', 'style': u'rpc'}, ) list_file_members_batch = bb.Route( 'list_file_members/batch', False, ListFileMembersBatchArg_validator, bv.List(ListFileMembersBatchResult_validator), SharingUserError_validator, {'host': u'api', 'style': u'rpc'}, ) list_file_members_continue = bb.Route( 'list_file_members/continue', False, ListFileMembersContinueArg_validator, SharedFileMembers_validator, ListFileMembersContinueError_validator, {'host': u'api', 'style': u'rpc'}, ) list_folder_members = bb.Route( 'list_folder_members', False, ListFolderMembersArgs_validator, SharedFolderMembers_validator, SharedFolderAccessError_validator, {'host': u'api', 'style': u'rpc'}, ) list_folder_members_continue = bb.Route( 'list_folder_members/continue', False, ListFolderMembersContinueArg_validator, SharedFolderMembers_validator, ListFolderMembersContinueError_validator, {'host': u'api', 'style': u'rpc'}, ) list_folders = bb.Route( 'list_folders', False, ListFoldersArgs_validator, ListFoldersResult_validator, bv.Void(), {'host': u'api', 'style': u'rpc'}, ) list_folders_continue = bb.Route( 'list_folders/continue', False, ListFoldersContinueArg_validator, ListFoldersResult_validator, ListFoldersContinueError_validator, {'host': u'api', 'style': u'rpc'}, ) list_mountable_folders = bb.Route( 'list_mountable_folders', False, ListFoldersArgs_validator, ListFoldersResult_validator, bv.Void(), {'host': u'api', 'style': u'rpc'}, ) list_mountable_folders_continue = bb.Route( 'list_mountable_folders/continue', False, ListFoldersContinueArg_validator, ListFoldersResult_validator, ListFoldersContinueError_validator, {'host': u'api', 'style': u'rpc'}, ) list_received_files = bb.Route( 'list_received_files', False, ListFilesArg_validator, ListFilesResult_validator, SharingUserError_validator, {'host': u'api', 'style': u'rpc'}, ) list_received_files_continue = bb.Route( 'list_received_files/continue', False, ListFilesContinueArg_validator, ListFilesResult_validator, ListFilesContinueError_validator, {'host': u'api', 'style': u'rpc'}, ) list_shared_links = bb.Route( 'list_shared_links', False, ListSharedLinksArg_validator, ListSharedLinksResult_validator, ListSharedLinksError_validator, {'host': u'api', 'style': u'rpc'}, ) modify_shared_link_settings = bb.Route( 'modify_shared_link_settings', False, ModifySharedLinkSettingsArgs_validator, SharedLinkMetadata_validator, ModifySharedLinkSettingsError_validator, {'host': u'api', 'style': u'rpc'}, ) mount_folder = bb.Route( 'mount_folder', False, MountFolderArg_validator, SharedFolderMetadata_validator, MountFolderError_validator, {'host': u'api', 'style': u'rpc'}, ) relinquish_file_membership = bb.Route( 'relinquish_file_membership', False, RelinquishFileMembershipArg_validator, bv.Void(), RelinquishFileMembershipError_validator, {'host': u'api', 'style': u'rpc'}, ) relinquish_folder_membership = bb.Route( 'relinquish_folder_membership', False, RelinquishFolderMembershipArg_validator, async.LaunchEmptyResult_validator, RelinquishFolderMembershipError_validator, {'host': u'api', 'style': u'rpc'}, ) remove_file_member = bb.Route( 'remove_file_member', True, RemoveFileMemberArg_validator, FileMemberActionIndividualResult_validator, RemoveFileMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) remove_file_member_2 = bb.Route( 'remove_file_member_2', False, RemoveFileMemberArg_validator, FileMemberRemoveActionResult_validator, RemoveFileMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) remove_folder_member = bb.Route( 'remove_folder_member', False, RemoveFolderMemberArg_validator, async.LaunchResultBase_validator, RemoveFolderMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) revoke_shared_link = bb.Route( 'revoke_shared_link', False, RevokeSharedLinkArg_validator, bv.Void(), RevokeSharedLinkError_validator, {'host': u'api', 'style': u'rpc'}, ) share_folder = bb.Route( 'share_folder', False, ShareFolderArg_validator, ShareFolderLaunch_validator, ShareFolderError_validator, {'host': u'api', 'style': u'rpc'}, ) transfer_folder = bb.Route( 'transfer_folder', False, TransferFolderArg_validator, bv.Void(), TransferFolderError_validator, {'host': u'api', 'style': u'rpc'}, ) unmount_folder = bb.Route( 'unmount_folder', False, UnmountFolderArg_validator, bv.Void(), UnmountFolderError_validator, {'host': u'api', 'style': u'rpc'}, ) unshare_file = bb.Route( 'unshare_file', False, UnshareFileArg_validator, bv.Void(), UnshareFileError_validator, {'host': u'api', 'style': u'rpc'}, ) unshare_folder = bb.Route( 'unshare_folder', False, UnshareFolderArg_validator, async.LaunchEmptyResult_validator, UnshareFolderError_validator, {'host': u'api', 'style': u'rpc'}, ) update_file_member = bb.Route( 'update_file_member', False, UpdateFileMemberArgs_validator, MemberAccessLevelResult_validator, FileMemberActionError_validator, {'host': u'api', 'style': u'rpc'}, ) update_folder_member = bb.Route( 'update_folder_member', False, UpdateFolderMemberArg_validator, MemberAccessLevelResult_validator, UpdateFolderMemberError_validator, {'host': u'api', 'style': u'rpc'}, ) update_folder_policy = bb.Route( 'update_folder_policy', False, UpdateFolderPolicyArg_validator, SharedFolderMetadata_validator, UpdateFolderPolicyError_validator, {'host': u'api', 'style': u'rpc'}, ) ROUTES = { 'add_file_member': add_file_member, 'add_folder_member': add_folder_member, 'change_file_member_access': change_file_member_access, 'check_job_status': check_job_status, 'check_remove_member_job_status': check_remove_member_job_status, 'check_share_job_status': check_share_job_status, 'create_shared_link': create_shared_link, 'create_shared_link_with_settings': create_shared_link_with_settings, 'get_file_metadata': get_file_metadata, 'get_file_metadata/batch': get_file_metadata_batch, 'get_folder_metadata': get_folder_metadata, 'get_shared_link_file': get_shared_link_file, 'get_shared_link_metadata': get_shared_link_metadata, 'get_shared_links': get_shared_links, 'list_file_members': list_file_members, 'list_file_members/batch': list_file_members_batch, 'list_file_members/continue': list_file_members_continue, 'list_folder_members': list_folder_members, 'list_folder_members/continue': list_folder_members_continue, 'list_folders': list_folders, 'list_folders/continue': list_folders_continue, 'list_mountable_folders': list_mountable_folders, 'list_mountable_folders/continue': list_mountable_folders_continue, 'list_received_files': list_received_files, 'list_received_files/continue': list_received_files_continue, 'list_shared_links': list_shared_links, 'modify_shared_link_settings': modify_shared_link_settings, 'mount_folder': mount_folder, 'relinquish_file_membership': relinquish_file_membership, 'relinquish_folder_membership': relinquish_folder_membership, 'remove_file_member': remove_file_member, 'remove_file_member_2': remove_file_member_2, 'remove_folder_member': remove_folder_member, 'revoke_shared_link': revoke_shared_link, 'share_folder': share_folder, 'transfer_folder': transfer_folder, 'unmount_folder': unmount_folder, 'unshare_file': unshare_file, 'unshare_folder': unshare_folder, 'update_file_member': update_file_member, 'update_folder_member': update_folder_member, 'update_folder_policy': update_folder_policy, }