mirror of
https://github.com/robweber/xbmcbackup.git
synced 2025-01-08 22:05:28 +01:00
19912 lines
638 KiB
Python
19912 lines
638 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Auto-generated by Stone, do not modify.
|
|
# @generated
|
|
# 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 (ImportError, 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,
|
|
seen_state,
|
|
team_common,
|
|
users,
|
|
users_common,
|
|
)
|
|
except (ImportError, SystemError, ValueError):
|
|
import async_
|
|
import common
|
|
import files
|
|
import seen_state
|
|
import team_common
|
|
import users
|
|
import users_common
|
|
|
|
class AccessInheritance(bb.Union):
|
|
"""
|
|
Information about the inheritance policy 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 sharing.AccessInheritance.inherit: The shared folder inherits its
|
|
members from the parent folder.
|
|
:ivar sharing.AccessInheritance.no_inherit: The shared folder does not
|
|
inherit its members from the parent folder.
|
|
"""
|
|
|
|
_catch_all = 'other'
|
|
# Attribute is overwritten below the class definition
|
|
inherit = None
|
|
# Attribute is overwritten below the class definition
|
|
no_inherit = None
|
|
# Attribute is overwritten below the class definition
|
|
other = None
|
|
|
|
def is_inherit(self):
|
|
"""
|
|
Check if the union tag is ``inherit``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'inherit'
|
|
|
|
def is_no_inherit(self):
|
|
"""
|
|
Check if the union tag is ``no_inherit``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'no_inherit'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AccessInheritance, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AccessInheritance(%r, %r)' % (self._tag, self._value)
|
|
|
|
AccessInheritance_validator = bv.Union(AccessInheritance)
|
|
|
|
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 sharing.AccessLevel.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 sharing.AccessLevel.editor: The collaborator can both view and edit
|
|
the shared folder.
|
|
:ivar sharing.AccessLevel.viewer: The collaborator can only view the shared
|
|
folder.
|
|
:ivar sharing.AccessLevel.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AccessLevel, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.AclUpdatePolicy.owner: Only the owner can update the ACL.
|
|
:ivar sharing.AclUpdatePolicy.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AclUpdatePolicy, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AclUpdatePolicy(%r, %r)' % (self._tag, self._value)
|
|
|
|
AclUpdatePolicy_validator = bv.Union(AclUpdatePolicy)
|
|
|
|
class AddFileMemberArgs(bb.Struct):
|
|
"""
|
|
Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_add_file_member`.
|
|
|
|
:ivar sharing.AddFileMemberArgs.file: File to which to add members.
|
|
:ivar sharing.AddFileMemberArgs.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 sharing.AddFileMemberArgs.custom_message: Message to send to added
|
|
members in their invitation.
|
|
:ivar sharing.AddFileMemberArgs.quiet: Whether added members should be
|
|
notified via device notifications of their invitation.
|
|
:ivar sharing.AddFileMemberArgs.access_level: AccessLevel union object,
|
|
describing what access level we want to give new members.
|
|
:ivar sharing.AddFileMemberArgs.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddFileMemberArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.AddFileMemberError.rate_limit: The user has reached the rate
|
|
limit for invitations.
|
|
:ivar sharing.AddFileMemberError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddFileMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AddFileMemberError(%r, %r)' % (self._tag, self._value)
|
|
|
|
AddFileMemberError_validator = bv.Union(AddFileMemberError)
|
|
|
|
class AddFolderMemberArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.AddFolderMemberArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.AddFolderMemberArg.members: The intended list of members to
|
|
add. Added members will receive invites to join the shared folder.
|
|
:ivar sharing.AddFolderMemberArg.quiet: Whether added members should be
|
|
notified via email and device notifications of their invite.
|
|
:ivar sharing.AddFolderMemberArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddFolderMemberArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 AddFolderMemberError.access_error: Unable to
|
|
access shared folder.
|
|
:ivar sharing.AddFolderMemberError.email_unverified: The current user's
|
|
e-mail address is unverified.
|
|
:ivar sharing.AddFolderMemberError.banned_member: The current user has been
|
|
banned.
|
|
:ivar AddMemberSelectorError AddFolderMemberError.bad_member:
|
|
``AddFolderMemberArg.members`` contains a bad invitation recipient.
|
|
:ivar sharing.AddFolderMemberError.cant_share_outside_team: Your team policy
|
|
does not allow sharing outside of the team.
|
|
:ivar int sharing.AddFolderMemberError.too_many_members: The value is the
|
|
member limit that was reached.
|
|
:ivar int sharing.AddFolderMemberError.too_many_pending_invites: The value
|
|
is the pending invite limit that was reached.
|
|
:ivar sharing.AddFolderMemberError.rate_limit: The current user has hit the
|
|
limit of invites they can send per day. Try again in 24 hours.
|
|
:ivar sharing.AddFolderMemberError.too_many_invitees: The current user is
|
|
trying to share with too many people at once.
|
|
:ivar sharing.AddFolderMemberError.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 sharing.AddFolderMemberError.team_folder: This action cannot be
|
|
performed on a team shared folder.
|
|
:ivar sharing.AddFolderMemberError.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
|
|
banned_member = 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 int 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 int 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_banned_member(self):
|
|
"""
|
|
Check if the union tag is ``banned_member``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'banned_member'
|
|
|
|
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: int
|
|
"""
|
|
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: int
|
|
"""
|
|
if not self.is_too_many_pending_invites():
|
|
raise AttributeError("tag 'too_many_pending_invites' not set")
|
|
return self._value
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddFolderMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AddFolderMemberError(%r, %r)' % (self._tag, self._value)
|
|
|
|
AddFolderMemberError_validator = bv.Union(AddFolderMemberError)
|
|
|
|
class AddMember(bb.Struct):
|
|
"""
|
|
The member and type of access the member should have when added to a shared
|
|
folder.
|
|
|
|
:ivar sharing.AddMember.member: The member to add to the shared folder.
|
|
:ivar sharing.AddMember.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddMember, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.AddMemberSelectorError.automatic_group: Automatically created
|
|
groups can only be added to team folders.
|
|
:ivar str sharing.AddMemberSelectorError.invalid_dropbox_id: The value is
|
|
the ID that could not be identified.
|
|
:ivar str sharing.AddMemberSelectorError.invalid_email: The value is the
|
|
e-email address that is malformed.
|
|
:ivar str sharing.AddMemberSelectorError.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 sharing.AddMemberSelectorError.group_deleted: At least one of the
|
|
specified groups in ``AddFolderMemberArg.members`` is deleted.
|
|
:ivar sharing.AddMemberSelectorError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AddMemberSelectorError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AddMemberSelectorError(%r, %r)' % (self._tag, self._value)
|
|
|
|
AddMemberSelectorError_validator = bv.Union(AddMemberSelectorError)
|
|
|
|
class AudienceExceptionContentInfo(bb.Struct):
|
|
"""
|
|
Information about the content that has a link audience different than that
|
|
of this folder.
|
|
|
|
:ivar sharing.AudienceExceptionContentInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AudienceExceptionContentInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AudienceExceptionContentInfo(name={!r})'.format(
|
|
self._name_value,
|
|
)
|
|
|
|
AudienceExceptionContentInfo_validator = bv.Struct(AudienceExceptionContentInfo)
|
|
|
|
class AudienceExceptions(bb.Struct):
|
|
"""
|
|
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 sharing.AudienceExceptions.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AudienceExceptions, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'AudienceExceptions(count={!r}, exceptions={!r})'.format(
|
|
self._count_value,
|
|
self._exceptions_value,
|
|
)
|
|
|
|
AudienceExceptions_validator = bv.Struct(AudienceExceptions)
|
|
|
|
class AudienceRestrictingSharedFolder(bb.Struct):
|
|
"""
|
|
Information about the shared folder that prevents the link audience for this
|
|
link from being more restrictive.
|
|
|
|
:ivar sharing.AudienceRestrictingSharedFolder.shared_folder_id: The ID of
|
|
the shared folder.
|
|
:ivar sharing.AudienceRestrictingSharedFolder.name: The name of the shared
|
|
folder.
|
|
:ivar sharing.AudienceRestrictingSharedFolder.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(AudienceRestrictingSharedFolder, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Arguments for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_change_file_member_access`.
|
|
|
|
:ivar sharing.ChangeFileMemberAccessArgs.file: File for which we are
|
|
changing a member's access.
|
|
:ivar sharing.ChangeFileMemberAccessArgs.member: The member whose access we
|
|
are changing.
|
|
:ivar sharing.ChangeFileMemberAccessArgs.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ChangeFileMemberAccessArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Metadata for a shared link. This can be either a :class:`PathLinkMetadata`
|
|
or :class:`CollectionLinkMetadata`.
|
|
|
|
:ivar sharing.LinkMetadata.url: URL of the shared link.
|
|
:ivar sharing.LinkMetadata.visibility: Who can access the link.
|
|
:ivar sharing.LinkMetadata.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(CollectionLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.CreateSharedLinkArg.path: The path to share.
|
|
:ivar sharing.CreateSharedLinkArg.short_url: Whether to return a shortened
|
|
URL.
|
|
:ivar sharing.CreateSharedLinkArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(CreateSharedLinkArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 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
|
|
"""
|
|
if not self.is_path():
|
|
raise AttributeError("tag 'path' not set")
|
|
return self._value
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(CreateSharedLinkError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'CreateSharedLinkError(%r, %r)' % (self._tag, self._value)
|
|
|
|
CreateSharedLinkError_validator = bv.Union(CreateSharedLinkError)
|
|
|
|
class CreateSharedLinkWithSettingsArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.CreateSharedLinkWithSettingsArg.path: The path to be shared by
|
|
the shared link.
|
|
:ivar sharing.CreateSharedLinkWithSettingsArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(CreateSharedLinkWithSettingsArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.CreateSharedLinkWithSettingsError.email_not_verified: User's
|
|
email should be verified.
|
|
:ivar Optional[SharedLinkAlreadyExistsMetadata]
|
|
sharing.CreateSharedLinkWithSettingsError.shared_link_already_exists:
|
|
The shared link already exists. You can call :route:`list_shared_links`
|
|
to get the existing link, or use the provided metadata if it is
|
|
returned.
|
|
:ivar SharedLinkSettingsError
|
|
CreateSharedLinkWithSettingsError.settings_error: There is an error with
|
|
the given settings.
|
|
:ivar sharing.CreateSharedLinkWithSettingsError.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
|
|
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 val:
|
|
:rtype: CreateSharedLinkWithSettingsError
|
|
"""
|
|
return cls('path', val)
|
|
|
|
@classmethod
|
|
def shared_link_already_exists(cls, val):
|
|
"""
|
|
Create an instance of this class set to the
|
|
``shared_link_already_exists`` tag with value ``val``.
|
|
|
|
:param SharedLinkAlreadyExistsMetadata val:
|
|
:rtype: CreateSharedLinkWithSettingsError
|
|
"""
|
|
return cls('shared_link_already_exists', 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
|
|
"""
|
|
if not self.is_path():
|
|
raise AttributeError("tag 'path' not set")
|
|
return self._value
|
|
|
|
def get_shared_link_already_exists(self):
|
|
"""
|
|
The shared link already exists. You can call
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` to get the
|
|
existing link, or use the provided metadata if it is returned.
|
|
|
|
Only call this if :meth:`is_shared_link_already_exists` is true.
|
|
|
|
:rtype: SharedLinkAlreadyExistsMetadata
|
|
"""
|
|
if not self.is_shared_link_already_exists():
|
|
raise AttributeError("tag 'shared_link_already_exists' 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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(CreateSharedLinkWithSettingsError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'CreateSharedLinkWithSettingsError(%r, %r)' % (self._tag, self._value)
|
|
|
|
CreateSharedLinkWithSettingsError_validator = bv.Union(CreateSharedLinkWithSettingsError)
|
|
|
|
class SharedContentLinkMetadataBase(bb.Struct):
|
|
"""
|
|
:ivar sharing.SharedContentLinkMetadataBase.access_level: The access level
|
|
on the link for this file.
|
|
:ivar sharing.SharedContentLinkMetadataBase.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
|
|
sharing.SharedContentLinkMetadataBase.audience_restricting_shared_folder:
|
|
The shared folder that prevents the link audience for this link from
|
|
being more restrictive.
|
|
:ivar sharing.SharedContentLinkMetadataBase.current_audience: The current
|
|
audience of the link.
|
|
:ivar sharing.SharedContentLinkMetadataBase.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 sharing.SharedContentLinkMetadataBase.link_permissions: A list of
|
|
permissions for actions you can perform on the link.
|
|
:ivar sharing.SharedContentLinkMetadataBase.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedContentLinkMetadataBase, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ExpectedSharedContentLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.FileAction.disable_viewer_info: Disable viewer information on
|
|
the file.
|
|
:ivar sharing.FileAction.edit_contents: Change or edit contents of the file.
|
|
:ivar sharing.FileAction.enable_viewer_info: Enable viewer information on
|
|
the file.
|
|
:ivar sharing.FileAction.invite_viewer: Add a member with view permissions.
|
|
:ivar sharing.FileAction.invite_viewer_no_comment: Add a member with view
|
|
permissions but no comment permissions.
|
|
:ivar sharing.FileAction.invite_editor: Add a member with edit permissions.
|
|
:ivar sharing.FileAction.unshare: Stop sharing this file.
|
|
:ivar sharing.FileAction.relinquish_membership: Relinquish one's own
|
|
membership to the file.
|
|
:ivar sharing.FileAction.share_link: Use create_view_link and
|
|
create_edit_link instead.
|
|
:ivar sharing.FileAction.create_link: Use create_view_link and
|
|
create_edit_link instead.
|
|
:ivar sharing.FileAction.create_view_link: Create a shared link to a file
|
|
that only allows users to view the content.
|
|
:ivar sharing.FileAction.create_edit_link: Create a shared link to a file
|
|
that allows users to edit the content.
|
|
"""
|
|
|
|
_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
|
|
invite_editor = 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
|
|
create_view_link = None
|
|
# Attribute is overwritten below the class definition
|
|
create_edit_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_invite_editor(self):
|
|
"""
|
|
Check if the union tag is ``invite_editor``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'invite_editor'
|
|
|
|
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_create_view_link(self):
|
|
"""
|
|
Check if the union tag is ``create_view_link``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'create_view_link'
|
|
|
|
def is_create_edit_link(self):
|
|
"""
|
|
Check if the union tag is ``create_edit_link``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'create_edit_link'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileAction, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.FileErrorResult.file_not_found_error: File specified by id
|
|
was not found.
|
|
:ivar str sharing.FileErrorResult.invalid_file_action_error: User does not
|
|
have permission to take the specified action on the file.
|
|
:ivar str sharing.FileErrorResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileErrorResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'FileErrorResult(%r, %r)' % (self._tag, self._value)
|
|
|
|
FileErrorResult_validator = bv.Union(FileErrorResult)
|
|
|
|
class SharedLinkMetadata(bb.Struct):
|
|
"""
|
|
The metadata of a shared link.
|
|
|
|
:ivar sharing.SharedLinkMetadata.url: URL of the shared link.
|
|
:ivar sharing.SharedLinkMetadata.id: A unique identifier for the linked
|
|
file.
|
|
:ivar sharing.SharedLinkMetadata.name: The linked file name (including
|
|
extension). This never contains a slash.
|
|
:ivar sharing.SharedLinkMetadata.expires: Expiration time, if set. By
|
|
default the link won't expire.
|
|
:ivar sharing.SharedLinkMetadata.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 sharing.SharedLinkMetadata.link_permissions: The link's access
|
|
permissions.
|
|
:ivar sharing.SharedLinkMetadata.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 sharing.SharedLinkMetadata.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
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.FileLinkMetadata.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 sharing.FileLinkMetadata.server_modified: The last time the file was
|
|
modified on Dropbox.
|
|
:ivar sharing.FileLinkMetadata.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 sharing.FileLinkMetadata.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.FileMemberActionError.invalid_member: Specified member was not
|
|
found.
|
|
:ivar sharing.FileMemberActionError.no_permission: User does not have
|
|
permission to perform this action on this member.
|
|
:ivar SharingFileAccessError FileMemberActionError.access_error: Specified
|
|
file was invalid or user does not have access.
|
|
:ivar MemberAccessLevelResult FileMemberActionError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileMemberActionError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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]
|
|
sharing.FileMemberActionIndividualResult.success: Member was
|
|
successfully removed from this file. If AccessLevel is given, the member
|
|
still has access via a parent shared folder.
|
|
:ivar FileMemberActionError FileMemberActionIndividualResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileMemberActionIndividualResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'FileMemberActionIndividualResult(%r, %r)' % (self._tag, self._value)
|
|
|
|
FileMemberActionIndividualResult_validator = bv.Union(FileMemberActionIndividualResult)
|
|
|
|
class FileMemberActionResult(bb.Struct):
|
|
"""
|
|
Per-member result for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_add_file_member` or
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_change_file_member_access`.
|
|
|
|
:ivar sharing.FileMemberActionResult.member: One of specified input members.
|
|
:ivar sharing.FileMemberActionResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileMemberActionResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 FileMemberRemoveActionResult.success: Member
|
|
was successfully removed from this file.
|
|
:ivar FileMemberActionError FileMemberRemoveActionResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FileMemberRemoveActionResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'FileMemberRemoveActionResult(%r, %r)' % (self._tag, self._value)
|
|
|
|
FileMemberRemoveActionResult_validator = bv.Union(FileMemberRemoveActionResult)
|
|
|
|
class FilePermission(bb.Struct):
|
|
"""
|
|
Whether the user is allowed to take the sharing action on the file.
|
|
|
|
:ivar sharing.FilePermission.action: The action that the user may wish to
|
|
take on the file.
|
|
:ivar sharing.FilePermission.allow: True if the user is allowed to take the
|
|
action.
|
|
:ivar sharing.FilePermission.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FilePermission, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.FolderAction.change_options: Change folder options, such as
|
|
who can be invited to join the folder.
|
|
:ivar sharing.FolderAction.disable_viewer_info: Disable viewer information
|
|
for this folder.
|
|
:ivar sharing.FolderAction.edit_contents: Change or edit contents of the
|
|
folder.
|
|
:ivar sharing.FolderAction.enable_viewer_info: Enable viewer information on
|
|
the folder.
|
|
:ivar sharing.FolderAction.invite_editor: Invite a user or group to join the
|
|
folder with read and write permission.
|
|
:ivar sharing.FolderAction.invite_viewer: Invite a user or group to join the
|
|
folder with read permission.
|
|
:ivar sharing.FolderAction.invite_viewer_no_comment: Invite a user or group
|
|
to join the folder with read permission but no comment permissions.
|
|
:ivar sharing.FolderAction.relinquish_membership: Relinquish one's own
|
|
membership in the folder.
|
|
:ivar sharing.FolderAction.unmount: Unmount the folder.
|
|
:ivar sharing.FolderAction.unshare: Stop sharing this folder.
|
|
:ivar sharing.FolderAction.leave_a_copy: Keep a copy of the contents upon
|
|
leaving or being kicked from the folder.
|
|
:ivar sharing.FolderAction.share_link: Use create_link instead.
|
|
:ivar sharing.FolderAction.create_link: Create a shared link for folder.
|
|
:ivar sharing.FolderAction.set_access_inheritance: Set whether the folder
|
|
inherits permissions from its parent.
|
|
"""
|
|
|
|
_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
|
|
set_access_inheritance = 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_set_access_inheritance(self):
|
|
"""
|
|
Check if the union tag is ``set_access_inheritance``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'set_access_inheritance'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FolderAction, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FolderLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Whether the user is allowed to take the action on the shared folder.
|
|
|
|
:ivar sharing.FolderPermission.action: The action that the user may wish to
|
|
take on the folder.
|
|
:ivar sharing.FolderPermission.allow: True if the user is allowed to take
|
|
the action.
|
|
:ivar sharing.FolderPermission.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FolderPermission, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
A set of policies governing membership and privileges for a shared folder.
|
|
|
|
:ivar sharing.FolderPolicy.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 sharing.FolderPolicy.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 sharing.FolderPolicy.acl_update_policy: Who can add and remove members
|
|
from this shared folder.
|
|
:ivar sharing.FolderPolicy.shared_link_policy: Who links can be shared with.
|
|
:ivar sharing.FolderPolicy.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(FolderPolicy, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Arguments of :meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata`.
|
|
|
|
:ivar sharing.GetFileMetadataArg.file: The file to query.
|
|
:ivar sharing.GetFileMetadataArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetFileMetadataArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'GetFileMetadataArg(file={!r}, actions={!r})'.format(
|
|
self._file_value,
|
|
self._actions_value,
|
|
)
|
|
|
|
GetFileMetadataArg_validator = bv.Struct(GetFileMetadataArg)
|
|
|
|
class GetFileMetadataBatchArg(bb.Struct):
|
|
"""
|
|
Arguments of
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata_batch`.
|
|
|
|
:ivar sharing.GetFileMetadataBatchArg.files: The files to query.
|
|
:ivar sharing.GetFileMetadataBatchArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetFileMetadataBatchArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'GetFileMetadataBatchArg(files={!r}, actions={!r})'.format(
|
|
self._files_value,
|
|
self._actions_value,
|
|
)
|
|
|
|
GetFileMetadataBatchArg_validator = bv.Struct(GetFileMetadataBatchArg)
|
|
|
|
class GetFileMetadataBatchResult(bb.Struct):
|
|
"""
|
|
Per file results of
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_get_file_metadata_batch`.
|
|
|
|
:ivar sharing.GetFileMetadataBatchResult.file: This is the input file
|
|
identifier corresponding to one of ``GetFileMetadataBatchArg.files``.
|
|
:ivar sharing.GetFileMetadataBatchResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetFileMetadataBatchResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetFileMetadataError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 GetFileMetadataIndividualResult.metadata: The
|
|
result for this file if it was successful.
|
|
:ivar SharingFileAccessError GetFileMetadataIndividualResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetFileMetadataIndividualResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'GetFileMetadataIndividualResult(%r, %r)' % (self._tag, self._value)
|
|
|
|
GetFileMetadataIndividualResult_validator = bv.Union(GetFileMetadataIndividualResult)
|
|
|
|
class GetMetadataArgs(bb.Struct):
|
|
"""
|
|
:ivar sharing.GetMetadataArgs.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.GetMetadataArgs.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetMetadataArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharedLinkError.shared_link_not_found: The shared link wasn't
|
|
found.
|
|
:ivar sharing.SharedLinkError.shared_link_access_denied: The caller is not
|
|
allowed to access this shared link.
|
|
:ivar sharing.SharedLinkError.unsupported_link_type: This type of link is
|
|
not supported; use :meth:`dropbox.dropbox.Dropbox.sharing_files`
|
|
instead.
|
|
"""
|
|
|
|
_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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.GetSharedLinkFileError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetSharedLinkFileError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'GetSharedLinkFileError(%r, %r)' % (self._tag, self._value)
|
|
|
|
GetSharedLinkFileError_validator = bv.Union(GetSharedLinkFileError)
|
|
|
|
class GetSharedLinkMetadataArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.GetSharedLinkMetadataArg.url: URL of the shared link.
|
|
:ivar sharing.GetSharedLinkMetadataArg.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 sharing.GetSharedLinkMetadataArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetSharedLinkMetadataArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.GetSharedLinksArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetSharedLinksArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetSharedLinksError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'GetSharedLinksError(%r, %r)' % (self._tag, self._value)
|
|
|
|
GetSharedLinksError_validator = bv.Union(GetSharedLinksError)
|
|
|
|
class GetSharedLinksResult(bb.Struct):
|
|
"""
|
|
:ivar sharing.GetSharedLinksResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GetSharedLinksResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.GroupInfo.group_type: The type of group.
|
|
:ivar sharing.GroupInfo.is_member: If the current user is a member of the
|
|
group.
|
|
:ivar sharing.GroupInfo.is_owner: If the current user is an owner of the
|
|
group.
|
|
:ivar sharing.GroupInfo.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
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GroupInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
The information about a member of the shared content.
|
|
|
|
:ivar sharing.MembershipInfo.access_type: The access type for this member.
|
|
It contains inherited access type from parent folder, and acquired
|
|
access type from this folder.
|
|
:ivar sharing.MembershipInfo.permissions: The permissions that requesting
|
|
user has on this member. The set of permissions corresponds to the
|
|
MemberActions in the request.
|
|
:ivar sharing.MembershipInfo.initials: Never set.
|
|
:ivar sharing.MembershipInfo.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. It contains inherited access type from
|
|
parent folder, and acquired access type from this 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 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):
|
|
"""
|
|
Never set.
|
|
|
|
: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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MembershipInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.GroupMembershipInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(GroupMembershipInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.InsufficientPlan.message: A message to tell the user to
|
|
upgrade in order to support expected action.
|
|
:ivar sharing.InsufficientPlan.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(InsufficientPlan, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.InsufficientQuotaAmounts.space_needed: The amount of space
|
|
needed to add the item (the size of the item).
|
|
:ivar sharing.InsufficientQuotaAmounts.space_shortage: The amount of extra
|
|
space needed to add the item.
|
|
:ivar sharing.InsufficientQuotaAmounts.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: int
|
|
"""
|
|
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: int
|
|
"""
|
|
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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(InsufficientQuotaAmounts, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.InviteeInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(InviteeInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.InviteeMembershipInfo.invitee: Recipient of the invitation.
|
|
:ivar sharing.InviteeMembershipInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(InviteeMembershipInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 JobError.unshare_folder_error: Error occurred while
|
|
performing :meth:`dropbox.dropbox.Dropbox.sharing_unshare_folder`
|
|
action.
|
|
:ivar RemoveFolderMemberError JobError.remove_folder_member_error: Error
|
|
occurred while performing
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_remove_folder_member` action.
|
|
:ivar RelinquishFolderMembershipError
|
|
JobError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(JobError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.JobStatus.complete: The asynchronous job has finished.
|
|
:ivar JobError JobStatus.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(JobStatus, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'JobStatus(%r, %r)' % (self._tag, self._value)
|
|
|
|
JobStatus_validator = bv.Union(JobStatus)
|
|
|
|
class LinkAccessLevel(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 sharing.LinkAccessLevel.viewer: Users who use the link can view and
|
|
comment on the content.
|
|
:ivar sharing.LinkAccessLevel.editor: Users who use the link can edit, view
|
|
and comment on the content.
|
|
"""
|
|
|
|
_catch_all = 'other'
|
|
# Attribute is overwritten below the class definition
|
|
viewer = None
|
|
# Attribute is overwritten below the class definition
|
|
editor = None
|
|
# Attribute is overwritten below the class definition
|
|
other = None
|
|
|
|
def is_viewer(self):
|
|
"""
|
|
Check if the union tag is ``viewer``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'viewer'
|
|
|
|
def is_editor(self):
|
|
"""
|
|
Check if the union tag is ``editor``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'editor'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkAccessLevel, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'LinkAccessLevel(%r, %r)' % (self._tag, self._value)
|
|
|
|
LinkAccessLevel_validator = bv.Union(LinkAccessLevel)
|
|
|
|
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 sharing.LinkAction.change_access_level: Change the access level of the
|
|
link.
|
|
:ivar sharing.LinkAction.change_audience: Change the audience of the link.
|
|
:ivar sharing.LinkAction.remove_expiry: Remove the expiry date of the link.
|
|
:ivar sharing.LinkAction.remove_password: Remove the password of the link.
|
|
:ivar sharing.LinkAction.set_expiry: Create or modify the expiry date of the
|
|
link.
|
|
:ivar sharing.LinkAction.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkAction, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.LinkAudience.public: Link is accessible by anyone.
|
|
:ivar sharing.LinkAudience.team: Link is accessible only by team members.
|
|
:ivar sharing.LinkAudience.no_one: The link can be used by no one. The link
|
|
merely points the user to the content, and does not grant additional
|
|
rights to the user. Members of the content who use this link can only
|
|
access the content with their pre-existing access rights.
|
|
:ivar sharing.LinkAudience.password: A link-specific password is required to
|
|
access the link. Login is not required.
|
|
:ivar sharing.LinkAudience.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
|
|
no_one = None
|
|
# Attribute is overwritten below the class definition
|
|
password = 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_no_one(self):
|
|
"""
|
|
Check if the union tag is ``no_one``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'no_one'
|
|
|
|
def is_password(self):
|
|
"""
|
|
Check if the union tag is ``password``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'password'
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkAudience, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.LinkExpiry.remove_expiry: Remove the currently set expiry for
|
|
the link.
|
|
:ivar datetime.datetime sharing.LinkExpiry.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkExpiry, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.LinkPassword.remove_password: Remove the currently set
|
|
password for the link.
|
|
:ivar str sharing.LinkPassword.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkPassword, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'LinkPassword(%r, %r)' % (self._tag, self._value)
|
|
|
|
LinkPassword_validator = bv.Union(LinkPassword)
|
|
|
|
class LinkPermission(bb.Struct):
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkPermission, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.LinkPermissions.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). For some links, an effective_audience value is returned
|
|
instead.
|
|
:ivar sharing.LinkPermissions.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 and resolved_visibility is returned instead
|
|
of effective_audience.
|
|
:ivar sharing.LinkPermissions.can_revoke: Whether the caller can revoke the
|
|
shared link.
|
|
:ivar sharing.LinkPermissions.revoke_failure_reason: The failure reason for
|
|
revoking the link. This field will only be present if the ``can_revoke``
|
|
is ``False``.
|
|
:ivar sharing.LinkPermissions.effective_audience: The type of audience who
|
|
can benefit from the access level specified by the `link_access_level`
|
|
field.
|
|
:ivar sharing.LinkPermissions.link_access_level: The access level that the
|
|
link will grant to its users. A link can grant additional rights to a
|
|
user beyond their current access level. For example, if a user was
|
|
invited as a viewer to a file, and then opens a link with
|
|
`link_access_level` set to `editor`, then they will gain editor
|
|
privileges. The `link_access_level` is a property of the link, and does
|
|
not depend on who is calling this API. In particular,
|
|
`link_access_level` does not take into account the API caller's current
|
|
permissions to the content.
|
|
"""
|
|
|
|
__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',
|
|
'_effective_audience_value',
|
|
'_effective_audience_present',
|
|
'_link_access_level_value',
|
|
'_link_access_level_present',
|
|
]
|
|
|
|
_has_required_fields = True
|
|
|
|
def __init__(self,
|
|
can_revoke=None,
|
|
resolved_visibility=None,
|
|
requested_visibility=None,
|
|
revoke_failure_reason=None,
|
|
effective_audience=None,
|
|
link_access_level=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
|
|
self._effective_audience_value = None
|
|
self._effective_audience_present = False
|
|
self._link_access_level_value = None
|
|
self._link_access_level_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
|
|
if effective_audience is not None:
|
|
self.effective_audience = effective_audience
|
|
if link_access_level is not None:
|
|
self.link_access_level = link_access_level
|
|
|
|
@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). For some links, an
|
|
effective_audience value is returned instead.
|
|
|
|
: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 and resolved_visibility is
|
|
returned instead of effective_audience.
|
|
|
|
: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
|
|
|
|
@property
|
|
def effective_audience(self):
|
|
"""
|
|
The type of audience who can benefit from the access level specified by
|
|
the `link_access_level` field.
|
|
|
|
:rtype: LinkAudience
|
|
"""
|
|
if self._effective_audience_present:
|
|
return self._effective_audience_value
|
|
else:
|
|
return None
|
|
|
|
@effective_audience.setter
|
|
def effective_audience(self, val):
|
|
if val is None:
|
|
del self.effective_audience
|
|
return
|
|
self._effective_audience_validator.validate_type_only(val)
|
|
self._effective_audience_value = val
|
|
self._effective_audience_present = True
|
|
|
|
@effective_audience.deleter
|
|
def effective_audience(self):
|
|
self._effective_audience_value = None
|
|
self._effective_audience_present = False
|
|
|
|
@property
|
|
def link_access_level(self):
|
|
"""
|
|
The access level that the link will grant to its users. A link can grant
|
|
additional rights to a user beyond their current access level. For
|
|
example, if a user was invited as a viewer to a file, and then opens a
|
|
link with `link_access_level` set to `editor`, then they will gain
|
|
editor privileges. The `link_access_level` is a property of the link,
|
|
and does not depend on who is calling this API. In particular,
|
|
`link_access_level` does not take into account the API caller's current
|
|
permissions to the content.
|
|
|
|
:rtype: LinkAccessLevel
|
|
"""
|
|
if self._link_access_level_present:
|
|
return self._link_access_level_value
|
|
else:
|
|
return None
|
|
|
|
@link_access_level.setter
|
|
def link_access_level(self, val):
|
|
if val is None:
|
|
del self.link_access_level
|
|
return
|
|
self._link_access_level_validator.validate_type_only(val)
|
|
self._link_access_level_value = val
|
|
self._link_access_level_present = True
|
|
|
|
@link_access_level.deleter
|
|
def link_access_level(self):
|
|
self._link_access_level_value = None
|
|
self._link_access_level_present = False
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkPermissions, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'LinkPermissions(can_revoke={!r}, resolved_visibility={!r}, requested_visibility={!r}, revoke_failure_reason={!r}, effective_audience={!r}, link_access_level={!r})'.format(
|
|
self._can_revoke_value,
|
|
self._resolved_visibility_value,
|
|
self._requested_visibility_value,
|
|
self._revoke_failure_reason_value,
|
|
self._effective_audience_value,
|
|
self._link_access_level_value,
|
|
)
|
|
|
|
LinkPermissions_validator = bv.Struct(LinkPermissions)
|
|
|
|
class LinkSettings(bb.Struct):
|
|
"""
|
|
Settings that apply to a link.
|
|
|
|
:ivar sharing.LinkSettings.access_level: The access level on the link for
|
|
this file. Currently, it only accepts 'viewer' and 'viewer_no_comment'.
|
|
:ivar sharing.LinkSettings.audience: The type of audience on the link for
|
|
this file.
|
|
:ivar sharing.LinkSettings.expiry: An expiry timestamp to set on a link.
|
|
:ivar sharing.LinkSettings.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(LinkSettings, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_file_members`.
|
|
|
|
:ivar sharing.ListFileMembersArg.file: The file for which you want to see
|
|
members.
|
|
:ivar sharing.ListFileMembersArg.actions: The actions for which to return
|
|
permissions on a member.
|
|
:ivar sharing.ListFileMembersArg.include_inherited: Whether to include
|
|
members who only have access from a parent shared folder.
|
|
:ivar sharing.ListFileMembersArg.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Arguments for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`.
|
|
|
|
:ivar sharing.ListFileMembersBatchArg.files: Files for which to return
|
|
members.
|
|
:ivar sharing.ListFileMembersBatchArg.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersBatchArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFileMembersBatchArg(files={!r}, limit={!r})'.format(
|
|
self._files_value,
|
|
self._limit_value,
|
|
)
|
|
|
|
ListFileMembersBatchArg_validator = bv.Struct(ListFileMembersBatchArg)
|
|
|
|
class ListFileMembersBatchResult(bb.Struct):
|
|
"""
|
|
Per-file result for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_batch`.
|
|
|
|
:ivar sharing.ListFileMembersBatchResult.file: This is the input file
|
|
identifier, whether an ID or a path.
|
|
:ivar sharing.ListFileMembersBatchResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersBatchResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFileMembersBatchResult(file={!r}, result={!r})'.format(
|
|
self._file_value,
|
|
self._result_value,
|
|
)
|
|
|
|
ListFileMembersBatchResult_validator = bv.Struct(ListFileMembersBatchResult)
|
|
|
|
class ListFileMembersContinueArg(bb.Struct):
|
|
"""
|
|
Arguments for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_file_members_continue`.
|
|
|
|
:ivar sharing.ListFileMembersContinueArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersContinueArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ListFileMembersContinueError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersContinueError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFileMembersContinueError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListFileMembersContinueError_validator = bv.Union(ListFileMembersContinueError)
|
|
|
|
class ListFileMembersCountResult(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListFileMembersCountResult.members: A list of members on this
|
|
file.
|
|
:ivar sharing.ListFileMembersCountResult.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersCountResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 ListFileMembersIndividualResult.result: The
|
|
results of the query for this file if it was successful.
|
|
:ivar SharingFileAccessError ListFileMembersIndividualResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFileMembersIndividualResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFileMembersIndividualResult(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListFileMembersIndividualResult_validator = bv.Union(ListFileMembersIndividualResult)
|
|
|
|
class ListFilesArg(bb.Struct):
|
|
"""
|
|
Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_list_received_files`.
|
|
|
|
:ivar sharing.ListFilesArg.limit: Number of files to return max per query.
|
|
Defaults to 100 if no limit is specified.
|
|
:ivar sharing.ListFilesArg.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFilesArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFilesArg(limit={!r}, actions={!r})'.format(
|
|
self._limit_value,
|
|
self._actions_value,
|
|
)
|
|
|
|
ListFilesArg_validator = bv.Struct(ListFilesArg)
|
|
|
|
class ListFilesContinueArg(bb.Struct):
|
|
"""
|
|
Arguments for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_received_files_continue`.
|
|
|
|
:ivar sharing.ListFilesContinueArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFilesContinueArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 ListFilesContinueError.user_error: User account had a
|
|
problem.
|
|
:ivar sharing.ListFilesContinueError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFilesContinueError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFilesContinueError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListFilesContinueError_validator = bv.Union(ListFilesContinueError)
|
|
|
|
class ListFilesResult(bb.Struct):
|
|
"""
|
|
Success results for
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_received_files`.
|
|
|
|
:ivar sharing.ListFilesResult.entries: Information about the files shared
|
|
with current user.
|
|
:ivar sharing.ListFilesResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFilesResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFilesResult(entries={!r}, cursor={!r})'.format(
|
|
self._entries_value,
|
|
self._cursor_value,
|
|
)
|
|
|
|
ListFilesResult_validator = bv.Struct(ListFilesResult)
|
|
|
|
class ListFolderMembersCursorArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListFolderMembersCursorArg.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 sharing.ListFolderMembersCursorArg.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFolderMembersCursorArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ListFolderMembersArgs.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFolderMembersArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListFolderMembersContinueArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFolderMembersContinueArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ListFolderMembersContinueError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFolderMembersContinueError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFolderMembersContinueError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListFolderMembersContinueError_validator = bv.Union(ListFolderMembersContinueError)
|
|
|
|
class ListFoldersArgs(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListFoldersArgs.limit: The maximum number of results to return
|
|
per request.
|
|
:ivar sharing.ListFoldersArgs.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: int
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFoldersArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFoldersArgs(limit={!r}, actions={!r})'.format(
|
|
self._limit_value,
|
|
self._actions_value,
|
|
)
|
|
|
|
ListFoldersArgs_validator = bv.Struct(ListFoldersArgs)
|
|
|
|
class ListFoldersContinueArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListFoldersContinueArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFoldersContinueArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ListFoldersContinueError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFoldersContinueError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFoldersContinueError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListFoldersContinueError_validator = bv.Union(ListFoldersContinueError)
|
|
|
|
class ListFoldersResult(bb.Struct):
|
|
"""
|
|
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 sharing.ListFoldersResult.entries: List of all shared folders the
|
|
authenticated user has access to.
|
|
:ivar sharing.ListFoldersResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListFoldersResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListFoldersResult(entries={!r}, cursor={!r})'.format(
|
|
self._entries_value,
|
|
self._cursor_value,
|
|
)
|
|
|
|
ListFoldersResult_validator = bv.Struct(ListFoldersResult)
|
|
|
|
class ListSharedLinksArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListSharedLinksArg.path: See
|
|
:meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links` description.
|
|
:ivar sharing.ListSharedLinksArg.cursor: The cursor returned by your last
|
|
call to :meth:`dropbox.dropbox.Dropbox.sharing_list_shared_links`.
|
|
:ivar sharing.ListSharedLinksArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListSharedLinksArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ListSharedLinksError.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 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
|
|
"""
|
|
if not self.is_path():
|
|
raise AttributeError("tag 'path' not set")
|
|
return self._value
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListSharedLinksError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ListSharedLinksError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ListSharedLinksError_validator = bv.Union(ListSharedLinksError)
|
|
|
|
class ListSharedLinksResult(bb.Struct):
|
|
"""
|
|
:ivar sharing.ListSharedLinksResult.links: Shared links applicable to the
|
|
path argument.
|
|
:ivar sharing.ListSharedLinksResult.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 sharing.ListSharedLinksResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ListSharedLinksResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Contains information about a member's access level to content after an
|
|
operation.
|
|
|
|
:ivar sharing.MemberAccessLevelResult.access_level: The member still has
|
|
this level of access to the content through a parent folder.
|
|
:ivar sharing.MemberAccessLevelResult.warning: A localized string with
|
|
additional information about why the user has this access level to the
|
|
content.
|
|
:ivar sharing.MemberAccessLevelResult.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MemberAccessLevelResult, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.MemberAction.leave_a_copy: Allow the member to keep a copy of
|
|
the folder when removing.
|
|
:ivar sharing.MemberAction.make_editor: Make the member an editor of the
|
|
folder.
|
|
:ivar sharing.MemberAction.make_owner: Make the member an owner of the
|
|
folder.
|
|
:ivar sharing.MemberAction.make_viewer: Make the member a viewer of the
|
|
folder.
|
|
:ivar sharing.MemberAction.make_viewer_no_comment: Make the member a viewer
|
|
of the folder without commenting permissions.
|
|
:ivar sharing.MemberAction.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MemberAction, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'MemberAction(%r, %r)' % (self._tag, self._value)
|
|
|
|
MemberAction_validator = bv.Union(MemberAction)
|
|
|
|
class MemberPermission(bb.Struct):
|
|
"""
|
|
Whether the user is allowed to take the action on the associated member.
|
|
|
|
:ivar sharing.MemberPermission.action: The action that the user may wish to
|
|
take on the member.
|
|
:ivar sharing.MemberPermission.allow: True if the user is allowed to take
|
|
the action.
|
|
:ivar sharing.MemberPermission.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MemberPermission, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.MemberPolicy.team: Only a teammate can become a member.
|
|
:ivar sharing.MemberPolicy.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MemberPolicy, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.MemberSelector.dropbox_id: Dropbox account, team member,
|
|
or group ID of member.
|
|
:ivar str sharing.MemberSelector.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MemberSelector, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'MemberSelector(%r, %r)' % (self._tag, self._value)
|
|
|
|
MemberSelector_validator = bv.Union(MemberSelector)
|
|
|
|
class ModifySharedLinkSettingsArgs(bb.Struct):
|
|
"""
|
|
:ivar sharing.ModifySharedLinkSettingsArgs.url: URL of the shared link to
|
|
change its settings.
|
|
:ivar sharing.ModifySharedLinkSettingsArgs.settings: Set of settings for the
|
|
shared link.
|
|
:ivar sharing.ModifySharedLinkSettingsArgs.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ModifySharedLinkSettingsArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 ModifySharedLinkSettingsError.settings_error:
|
|
There is an error with the given settings.
|
|
:ivar sharing.ModifySharedLinkSettingsError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ModifySharedLinkSettingsError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ModifySharedLinkSettingsError(%r, %r)' % (self._tag, self._value)
|
|
|
|
ModifySharedLinkSettingsError_validator = bv.Union(ModifySharedLinkSettingsError)
|
|
|
|
class MountFolderArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.MountFolderArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MountFolderArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.MountFolderError.inside_shared_folder: Mounting would cause a
|
|
shared folder to be inside another, which is disallowed.
|
|
:ivar InsufficientQuotaAmounts MountFolderError.insufficient_quota: The
|
|
current user does not have enough space to mount the shared folder.
|
|
:ivar sharing.MountFolderError.already_mounted: The shared folder is already
|
|
mounted.
|
|
:ivar sharing.MountFolderError.no_permission: The current user does not have
|
|
permission to perform this action.
|
|
:ivar sharing.MountFolderError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(MountFolderError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'MountFolderError(%r, %r)' % (self._tag, self._value)
|
|
|
|
MountFolderError_validator = bv.Union(MountFolderError)
|
|
|
|
class ParentFolderAccessInfo(bb.Struct):
|
|
"""
|
|
Contains information about a parent folder that a member has access to.
|
|
|
|
:ivar sharing.ParentFolderAccessInfo.folder_name: Display name for the
|
|
folder.
|
|
:ivar sharing.ParentFolderAccessInfo.shared_folder_id: The identifier of the
|
|
parent shared folder.
|
|
:ivar sharing.ParentFolderAccessInfo.permissions: The user's permissions for
|
|
the parent shared folder.
|
|
:ivar sharing.ParentFolderAccessInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ParentFolderAccessInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.PathLinkMetadata.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(PathLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.PendingUploadMode.file: Assume pending uploads are files.
|
|
:ivar sharing.PendingUploadMode.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(PendingUploadMode, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.PermissionDeniedReason.user_not_same_team_as_owner: User is
|
|
not on the same team as the folder owner.
|
|
:ivar sharing.PermissionDeniedReason.user_not_allowed_by_owner: User is
|
|
prohibited by the owner from taking the action.
|
|
:ivar sharing.PermissionDeniedReason.target_is_indirect_member: Target is
|
|
indirectly a member of the folder, for example by being part of a group.
|
|
:ivar sharing.PermissionDeniedReason.target_is_owner: Target is the owner of
|
|
the folder.
|
|
:ivar sharing.PermissionDeniedReason.target_is_self: Target is the user
|
|
itself.
|
|
:ivar sharing.PermissionDeniedReason.target_not_active: Target is not an
|
|
active member of the team.
|
|
:ivar sharing.PermissionDeniedReason.folder_is_limited_team_folder: Folder
|
|
is team folder for a limited team.
|
|
:ivar sharing.PermissionDeniedReason.owner_not_on_team: The content owner
|
|
needs to be on a Dropbox team to perform this action.
|
|
:ivar sharing.PermissionDeniedReason.permission_denied: The user does not
|
|
have permission to perform this action on the link.
|
|
:ivar sharing.PermissionDeniedReason.restricted_by_team: The user's team
|
|
policy prevents performing this action on the link.
|
|
:ivar sharing.PermissionDeniedReason.user_account_type: The user's account
|
|
type does not support this action.
|
|
:ivar sharing.PermissionDeniedReason.user_not_on_team: The user needs to be
|
|
on a Dropbox team to perform this action.
|
|
:ivar sharing.PermissionDeniedReason.folder_is_inside_shared_folder: Folder
|
|
is inside of another shared folder.
|
|
:ivar sharing.PermissionDeniedReason.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(PermissionDeniedReason, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'PermissionDeniedReason(%r, %r)' % (self._tag, self._value)
|
|
|
|
PermissionDeniedReason_validator = bv.Union(PermissionDeniedReason)
|
|
|
|
class RelinquishFileMembershipArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.RelinquishFileMembershipArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RelinquishFileMembershipArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.RelinquishFileMembershipError.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 sharing.RelinquishFileMembershipError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RelinquishFileMembershipError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RelinquishFileMembershipError(%r, %r)' % (self._tag, self._value)
|
|
|
|
RelinquishFileMembershipError_validator = bv.Union(RelinquishFileMembershipError)
|
|
|
|
class RelinquishFolderMembershipArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.RelinquishFolderMembershipArg.shared_folder_id: The ID for the
|
|
shared folder.
|
|
:ivar sharing.RelinquishFolderMembershipArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RelinquishFolderMembershipArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.RelinquishFolderMembershipError.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 sharing.RelinquishFolderMembershipError.mounted: The shared folder is
|
|
currently mounted. Unmount the shared folder before relinquishing
|
|
membership.
|
|
:ivar sharing.RelinquishFolderMembershipError.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 sharing.RelinquishFolderMembershipError.team_folder: This action
|
|
cannot be performed on a team shared folder.
|
|
:ivar sharing.RelinquishFolderMembershipError.no_permission: The current
|
|
user does not have permission to perform this action.
|
|
:ivar sharing.RelinquishFolderMembershipError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RelinquishFolderMembershipError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RelinquishFolderMembershipError(%r, %r)' % (self._tag, self._value)
|
|
|
|
RelinquishFolderMembershipError_validator = bv.Union(RelinquishFolderMembershipError)
|
|
|
|
class RemoveFileMemberArg(bb.Struct):
|
|
"""
|
|
Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_remove_file_member_2`.
|
|
|
|
:ivar sharing.RemoveFileMemberArg.file: File from which to remove members.
|
|
:ivar sharing.RemoveFileMemberArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RemoveFileMemberArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 RemoveFileMemberError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RemoveFileMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RemoveFileMemberError(%r, %r)' % (self._tag, self._value)
|
|
|
|
RemoveFileMemberError_validator = bv.Union(RemoveFileMemberError)
|
|
|
|
class RemoveFolderMemberArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.RemoveFolderMemberArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.RemoveFolderMemberArg.member: The member to remove from the
|
|
folder.
|
|
:ivar sharing.RemoveFolderMemberArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RemoveFolderMemberArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.RemoveFolderMemberError.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 sharing.RemoveFolderMemberError.group_access: The target user has
|
|
access to the shared folder via a group.
|
|
:ivar sharing.RemoveFolderMemberError.team_folder: This action cannot be
|
|
performed on a team shared folder.
|
|
:ivar sharing.RemoveFolderMemberError.no_permission: The current user does
|
|
not have permission to perform this action.
|
|
:ivar sharing.RemoveFolderMemberError.too_many_files: This shared folder has
|
|
too many files for leaving a copy. You can still remove this user
|
|
without leaving a copy.
|
|
"""
|
|
|
|
_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
|
|
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: 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_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 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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RemoveFolderMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 RemoveMemberJobStatus.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RemoveMemberJobStatus, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RemoveMemberJobStatus(%r, %r)' % (self._tag, self._value)
|
|
|
|
RemoveMemberJobStatus_validator = bv.Union(RemoveMemberJobStatus)
|
|
|
|
class RequestedLinkAccessLevel(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 sharing.RequestedLinkAccessLevel.viewer: Users who use the link can
|
|
view and comment on the content.
|
|
:ivar sharing.RequestedLinkAccessLevel.editor: Users who use the link can
|
|
edit, view and comment on the content.
|
|
:ivar sharing.RequestedLinkAccessLevel.max: Request for the maximum access
|
|
level you can set the link to.
|
|
"""
|
|
|
|
_catch_all = 'other'
|
|
# Attribute is overwritten below the class definition
|
|
viewer = None
|
|
# Attribute is overwritten below the class definition
|
|
editor = None
|
|
# Attribute is overwritten below the class definition
|
|
max = None
|
|
# Attribute is overwritten below the class definition
|
|
other = None
|
|
|
|
def is_viewer(self):
|
|
"""
|
|
Check if the union tag is ``viewer``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'viewer'
|
|
|
|
def is_editor(self):
|
|
"""
|
|
Check if the union tag is ``editor``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'editor'
|
|
|
|
def is_max(self):
|
|
"""
|
|
Check if the union tag is ``max``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'max'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RequestedLinkAccessLevel, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RequestedLinkAccessLevel(%r, %r)' % (self._tag, self._value)
|
|
|
|
RequestedLinkAccessLevel_validator = bv.Union(RequestedLinkAccessLevel)
|
|
|
|
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 sharing.RequestedVisibility.public: Anyone who has received the link
|
|
can access it. No login required.
|
|
:ivar sharing.RequestedVisibility.team_only: Only members of the same team
|
|
can access the link. Login is required.
|
|
:ivar sharing.RequestedVisibility.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RequestedVisibility, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ResolvedVisibility.team_and_password: Only members of the same
|
|
team who have the link-specific password can access the link. Login is
|
|
required.
|
|
:ivar sharing.ResolvedVisibility.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ResolvedVisibility, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'ResolvedVisibility(%r, %r)' % (self._tag, self._value)
|
|
|
|
ResolvedVisibility_validator = bv.Union(ResolvedVisibility)
|
|
|
|
class RevokeSharedLinkArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.RevokeSharedLinkArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RevokeSharedLinkArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.RevokeSharedLinkError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(RevokeSharedLinkError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'RevokeSharedLinkError(%r, %r)' % (self._tag, self._value)
|
|
|
|
RevokeSharedLinkError_validator = bv.Union(RevokeSharedLinkError)
|
|
|
|
class SetAccessInheritanceArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.SetAccessInheritanceArg.access_inheritance: The access
|
|
inheritance settings for the folder.
|
|
:ivar sharing.SetAccessInheritanceArg.shared_folder_id: The ID for the
|
|
shared folder.
|
|
"""
|
|
|
|
__slots__ = [
|
|
'_access_inheritance_value',
|
|
'_access_inheritance_present',
|
|
'_shared_folder_id_value',
|
|
'_shared_folder_id_present',
|
|
]
|
|
|
|
_has_required_fields = True
|
|
|
|
def __init__(self,
|
|
shared_folder_id=None,
|
|
access_inheritance=None):
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_present = False
|
|
self._shared_folder_id_value = None
|
|
self._shared_folder_id_present = False
|
|
if access_inheritance is not None:
|
|
self.access_inheritance = access_inheritance
|
|
if shared_folder_id is not None:
|
|
self.shared_folder_id = shared_folder_id
|
|
|
|
@property
|
|
def access_inheritance(self):
|
|
"""
|
|
The access inheritance settings for the folder.
|
|
|
|
:rtype: AccessInheritance
|
|
"""
|
|
if self._access_inheritance_present:
|
|
return self._access_inheritance_value
|
|
else:
|
|
return AccessInheritance.inherit
|
|
|
|
@access_inheritance.setter
|
|
def access_inheritance(self, val):
|
|
self._access_inheritance_validator.validate_type_only(val)
|
|
self._access_inheritance_value = val
|
|
self._access_inheritance_present = True
|
|
|
|
@access_inheritance.deleter
|
|
def access_inheritance(self):
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_present = False
|
|
|
|
@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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SetAccessInheritanceArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SetAccessInheritanceArg(shared_folder_id={!r}, access_inheritance={!r})'.format(
|
|
self._shared_folder_id_value,
|
|
self._access_inheritance_value,
|
|
)
|
|
|
|
SetAccessInheritanceArg_validator = bv.Struct(SetAccessInheritanceArg)
|
|
|
|
class SetAccessInheritanceError(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 SetAccessInheritanceError.access_error: Unable
|
|
to access shared folder.
|
|
:ivar sharing.SetAccessInheritanceError.no_permission: The current user does
|
|
not have permission to perform this action.
|
|
"""
|
|
|
|
_catch_all = 'other'
|
|
# 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: SetAccessInheritanceError
|
|
"""
|
|
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_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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SetAccessInheritanceError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SetAccessInheritanceError(%r, %r)' % (self._tag, self._value)
|
|
|
|
SetAccessInheritanceError_validator = bv.Union(SetAccessInheritanceError)
|
|
|
|
class ShareFolderArgBase(bb.Struct):
|
|
"""
|
|
:ivar sharing.ShareFolderArgBase.acl_update_policy: Who can add and remove
|
|
members of this shared folder.
|
|
:ivar sharing.ShareFolderArgBase.force_async: Whether to force the share to
|
|
happen asynchronously.
|
|
:ivar sharing.ShareFolderArgBase.member_policy: Who can be a member of this
|
|
shared folder. Only applicable if the current user is on a team.
|
|
:ivar sharing.ShareFolderArgBase.path: The path to the folder to share. If
|
|
it does not exist, then a new one is created.
|
|
:ivar sharing.ShareFolderArgBase.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 sharing.ShareFolderArgBase.viewer_info_policy: Who can enable/disable
|
|
viewer info for this shared folder.
|
|
:ivar sharing.ShareFolderArgBase.access_inheritance: The access inheritance
|
|
settings for the 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',
|
|
'_access_inheritance_value',
|
|
'_access_inheritance_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,
|
|
access_inheritance=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
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_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
|
|
if access_inheritance is not None:
|
|
self.access_inheritance = access_inheritance
|
|
|
|
@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
|
|
|
|
@property
|
|
def access_inheritance(self):
|
|
"""
|
|
The access inheritance settings for the folder.
|
|
|
|
:rtype: AccessInheritance
|
|
"""
|
|
if self._access_inheritance_present:
|
|
return self._access_inheritance_value
|
|
else:
|
|
return AccessInheritance.inherit
|
|
|
|
@access_inheritance.setter
|
|
def access_inheritance(self, val):
|
|
self._access_inheritance_validator.validate_type_only(val)
|
|
self._access_inheritance_value = val
|
|
self._access_inheritance_present = True
|
|
|
|
@access_inheritance.deleter
|
|
def access_inheritance(self):
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_present = False
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderArgBase, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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}, access_inheritance={!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._access_inheritance_value,
|
|
)
|
|
|
|
ShareFolderArgBase_validator = bv.Struct(ShareFolderArgBase)
|
|
|
|
class ShareFolderArg(ShareFolderArgBase):
|
|
"""
|
|
:ivar sharing.ShareFolderArg.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 sharing.ShareFolderArg.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,
|
|
access_inheritance=None,
|
|
actions=None,
|
|
link_settings=None):
|
|
super(ShareFolderArg, self).__init__(path,
|
|
acl_update_policy,
|
|
force_async,
|
|
member_policy,
|
|
shared_link_policy,
|
|
viewer_info_policy,
|
|
access_inheritance)
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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}, access_inheritance={!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._access_inheritance_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 sharing.ShareFolderErrorBase.email_unverified: The current user's
|
|
e-mail address is unverified.
|
|
:ivar SharePathError ShareFolderErrorBase.bad_path: ``ShareFolderArg.path``
|
|
is invalid.
|
|
:ivar sharing.ShareFolderErrorBase.team_policy_disallows_member_policy: Team
|
|
policy is more restrictive than ``ShareFolderArg.member_policy``.
|
|
:ivar sharing.ShareFolderErrorBase.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderErrorBase, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.ShareFolderError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 ShareFolderJobStatus.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderJobStatus, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ShareFolderLaunch, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharePathError.is_file: A file is at the specified path.
|
|
:ivar sharing.SharePathError.inside_shared_folder: We do not support sharing
|
|
a folder inside a shared folder.
|
|
:ivar sharing.SharePathError.contains_shared_folder: We do not support
|
|
shared folders that contain shared folders.
|
|
:ivar sharing.SharePathError.contains_app_folder: We do not support shared
|
|
folders that contain app folders.
|
|
:ivar sharing.SharePathError.contains_team_folder: We do not support shared
|
|
folders that contain team folders.
|
|
:ivar sharing.SharePathError.is_app_folder: We do not support sharing an app
|
|
folder.
|
|
:ivar sharing.SharePathError.inside_app_folder: We do not support sharing a
|
|
folder inside an app folder.
|
|
:ivar sharing.SharePathError.is_public_folder: A public folder can't be
|
|
shared this way. Use a public link instead.
|
|
:ivar sharing.SharePathError.inside_public_folder: A folder inside a public
|
|
folder can't be shared this way. Use a public link instead.
|
|
:ivar SharedFolderMetadata SharePathError.already_shared: Folder is already
|
|
shared. Contains metadata about the existing shared folder.
|
|
:ivar sharing.SharePathError.invalid_path: Path is not valid.
|
|
:ivar sharing.SharePathError.is_osx_package: We do not support sharing a Mac
|
|
OS X package.
|
|
:ivar sharing.SharePathError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharePathError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharedContentLinkMetadata.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 sharing.SharedContentLinkMetadata.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedContentLinkMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
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 sharing.SharedFileMembers.users: The list of user members of the
|
|
shared file.
|
|
:ivar sharing.SharedFileMembers.groups: The list of group members of the
|
|
shared file.
|
|
:ivar sharing.SharedFileMembers.invitees: The list of invited members of a
|
|
file, but have not logged in and claimed this.
|
|
:ivar sharing.SharedFileMembers.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFileMembers, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Properties of the shared file.
|
|
|
|
:ivar sharing.SharedFileMetadata.access_type: The current user's access
|
|
level for this shared file.
|
|
:ivar sharing.SharedFileMetadata.id: The ID of the file.
|
|
:ivar sharing.SharedFileMetadata.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 sharing.SharedFileMetadata.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 sharing.SharedFileMetadata.name: The name of this file.
|
|
:ivar sharing.SharedFileMetadata.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 sharing.SharedFileMetadata.owner_team: The team that owns the file.
|
|
This field is not present if the file is not owned by a team.
|
|
:ivar sharing.SharedFileMetadata.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 sharing.SharedFileMetadata.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 sharing.SharedFileMetadata.path_lower: The lower-case full path of
|
|
this file. Absent for unmounted files.
|
|
:ivar sharing.SharedFileMetadata.permissions: The sharing permissions that
|
|
requesting user has on this file. This corresponds to the entries given
|
|
in ``GetFileMetadataBatchArg.actions`` or
|
|
``GetFileMetadataArg.actions``.
|
|
:ivar sharing.SharedFileMetadata.policy: Policies governing this shared
|
|
file.
|
|
:ivar sharing.SharedFileMetadata.preview_url: URL for displaying a web
|
|
preview of the shared file.
|
|
:ivar sharing.SharedFileMetadata.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
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFileMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharedFolderAccessError.invalid_id: This shared folder ID is
|
|
invalid.
|
|
:ivar sharing.SharedFolderAccessError.not_a_member: The user is not a member
|
|
of the shared folder thus cannot access it.
|
|
:ivar sharing.SharedFolderAccessError.email_unverified: Never set.
|
|
:ivar sharing.SharedFolderAccessError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFolderAccessError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharedFolderMemberError.invalid_dropbox_id: The target
|
|
dropbox_id is invalid.
|
|
:ivar sharing.SharedFolderMemberError.not_a_member: The target dropbox_id is
|
|
not a member of the shared folder.
|
|
:ivar MemberAccessLevelResult SharedFolderMemberError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFolderMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharedFolderMemberError(%r, %r)' % (self._tag, self._value)
|
|
|
|
SharedFolderMemberError_validator = bv.Union(SharedFolderMemberError)
|
|
|
|
class SharedFolderMembers(bb.Struct):
|
|
"""
|
|
Shared folder user and group membership.
|
|
|
|
:ivar sharing.SharedFolderMembers.users: The list of user members of the
|
|
shared folder.
|
|
:ivar sharing.SharedFolderMembers.groups: The list of group members of the
|
|
shared folder.
|
|
:ivar sharing.SharedFolderMembers.invitees: The list of invitees to the
|
|
shared folder.
|
|
:ivar sharing.SharedFolderMembers.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFolderMembers, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
Properties of the shared folder.
|
|
|
|
:ivar sharing.SharedFolderMetadataBase.access_type: The current user's
|
|
access level for this shared folder.
|
|
:ivar sharing.SharedFolderMetadataBase.is_inside_team_folder: Whether this
|
|
folder is inside of a team folder.
|
|
:ivar sharing.SharedFolderMetadataBase.is_team_folder: Whether this folder
|
|
is a `team folder <https://www.dropbox.com/en/help/986>`_.
|
|
:ivar sharing.SharedFolderMetadataBase.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 sharing.SharedFolderMetadataBase.owner_team: The team that owns the
|
|
folder. This field is not present if the folder is not owned by a team.
|
|
:ivar sharing.SharedFolderMetadataBase.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 sharing.SharedFolderMetadataBase.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
|
|
<https://www.dropbox.com/en/help/986>`_.
|
|
|
|
: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
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFolderMetadataBase, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharedFolderMetadata.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 sharing.SharedFolderMetadata.name: The name of the this shared folder.
|
|
:ivar sharing.SharedFolderMetadata.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 sharing.SharedFolderMetadata.policy: Policies governing this shared
|
|
folder.
|
|
:ivar sharing.SharedFolderMetadata.preview_url: URL for displaying a web
|
|
preview of the shared folder.
|
|
:ivar sharing.SharedFolderMetadata.shared_folder_id: The ID of the shared
|
|
folder.
|
|
:ivar sharing.SharedFolderMetadata.time_invited: Timestamp indicating when
|
|
the current user was invited to this shared folder.
|
|
:ivar sharing.SharedFolderMetadata.access_inheritance: Whether the folder
|
|
inherits its members from its parent.
|
|
"""
|
|
|
|
__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',
|
|
'_access_inheritance_value',
|
|
'_access_inheritance_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,
|
|
access_inheritance=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
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_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
|
|
if access_inheritance is not None:
|
|
self.access_inheritance = access_inheritance
|
|
|
|
@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
|
|
|
|
@property
|
|
def access_inheritance(self):
|
|
"""
|
|
Whether the folder inherits its members from its parent.
|
|
|
|
:rtype: AccessInheritance
|
|
"""
|
|
if self._access_inheritance_present:
|
|
return self._access_inheritance_value
|
|
else:
|
|
return AccessInheritance.inherit
|
|
|
|
@access_inheritance.setter
|
|
def access_inheritance(self, val):
|
|
self._access_inheritance_validator.validate_type_only(val)
|
|
self._access_inheritance_value = val
|
|
self._access_inheritance_present = True
|
|
|
|
@access_inheritance.deleter
|
|
def access_inheritance(self):
|
|
self._access_inheritance_value = None
|
|
self._access_inheritance_present = False
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedFolderMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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}, access_inheritance={!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,
|
|
self._access_inheritance_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 sharing.SharedLinkAccessFailureReason.login_required: User is not
|
|
logged in.
|
|
:ivar sharing.SharedLinkAccessFailureReason.email_verify_required: User's
|
|
email is not verified.
|
|
:ivar sharing.SharedLinkAccessFailureReason.password_required: The link is
|
|
password protected.
|
|
:ivar sharing.SharedLinkAccessFailureReason.team_only: Access is allowed for
|
|
team members only.
|
|
:ivar sharing.SharedLinkAccessFailureReason.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkAccessFailureReason, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharedLinkAccessFailureReason(%r, %r)' % (self._tag, self._value)
|
|
|
|
SharedLinkAccessFailureReason_validator = bv.Union(SharedLinkAccessFailureReason)
|
|
|
|
class SharedLinkAlreadyExistsMetadata(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 SharedLinkMetadata SharedLinkAlreadyExistsMetadata.metadata: Metadata
|
|
of the shared link that already exists.
|
|
"""
|
|
|
|
_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 SharedLinkMetadata val:
|
|
:rtype: SharedLinkAlreadyExistsMetadata
|
|
"""
|
|
return cls('metadata', val)
|
|
|
|
def is_metadata(self):
|
|
"""
|
|
Check if the union tag is ``metadata``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'metadata'
|
|
|
|
def is_other(self):
|
|
"""
|
|
Check if the union tag is ``other``.
|
|
|
|
:rtype: bool
|
|
"""
|
|
return self._tag == 'other'
|
|
|
|
def get_metadata(self):
|
|
"""
|
|
Metadata of the shared link that already exists.
|
|
|
|
Only call this if :meth:`is_metadata` is true.
|
|
|
|
:rtype: SharedLinkMetadata
|
|
"""
|
|
if not self.is_metadata():
|
|
raise AttributeError("tag 'metadata' not set")
|
|
return self._value
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkAlreadyExistsMetadata, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharedLinkAlreadyExistsMetadata(%r, %r)' % (self._tag, self._value)
|
|
|
|
SharedLinkAlreadyExistsMetadata_validator = bv.Union(SharedLinkAlreadyExistsMetadata)
|
|
|
|
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 sharing.SharedLinkPolicy.anyone: Links can be shared with anyone.
|
|
:ivar sharing.SharedLinkPolicy.team: Links can be shared with anyone on the
|
|
same team as the owner.
|
|
:ivar sharing.SharedLinkPolicy.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkPolicy, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharedLinkPolicy(%r, %r)' % (self._tag, self._value)
|
|
|
|
SharedLinkPolicy_validator = bv.Union(SharedLinkPolicy)
|
|
|
|
class SharedLinkSettings(bb.Struct):
|
|
"""
|
|
:ivar sharing.SharedLinkSettings.requested_visibility: The requested access
|
|
for this shared link.
|
|
:ivar sharing.SharedLinkSettings.link_password: If ``requested_visibility``
|
|
is ``RequestedVisibility.password`` this is needed to specify the
|
|
password to access the link.
|
|
:ivar sharing.SharedLinkSettings.expires: Expiration time of the shared
|
|
link. By default the link won't expire.
|
|
:ivar sharing.SharedLinkSettings.audience: The new audience who can benefit
|
|
from the access level specified by the link's access level specified in
|
|
the `link_access_level` field of `LinkPermissions`. This is used in
|
|
conjunction with team policies and shared folder policies to determine
|
|
the final effective audience type in the `effective_audience` field of
|
|
`LinkPermissions.
|
|
:ivar sharing.SharedLinkSettings.access: Requested access level you want the
|
|
audience to gain from this link.
|
|
"""
|
|
|
|
__slots__ = [
|
|
'_requested_visibility_value',
|
|
'_requested_visibility_present',
|
|
'_link_password_value',
|
|
'_link_password_present',
|
|
'_expires_value',
|
|
'_expires_present',
|
|
'_audience_value',
|
|
'_audience_present',
|
|
'_access_value',
|
|
'_access_present',
|
|
]
|
|
|
|
_has_required_fields = False
|
|
|
|
def __init__(self,
|
|
requested_visibility=None,
|
|
link_password=None,
|
|
expires=None,
|
|
audience=None,
|
|
access=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
|
|
self._audience_value = None
|
|
self._audience_present = False
|
|
self._access_value = None
|
|
self._access_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
|
|
if audience is not None:
|
|
self.audience = audience
|
|
if access is not None:
|
|
self.access = access
|
|
|
|
@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
|
|
|
|
@property
|
|
def audience(self):
|
|
"""
|
|
The new audience who can benefit from the access level specified by the
|
|
link's access level specified in the `link_access_level` field of
|
|
`LinkPermissions`. This is used in conjunction with team policies and
|
|
shared folder policies to determine the final effective audience type in
|
|
the `effective_audience` field of `LinkPermissions.
|
|
|
|
: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 access(self):
|
|
"""
|
|
Requested access level you want the audience to gain from this link.
|
|
|
|
:rtype: RequestedLinkAccessLevel
|
|
"""
|
|
if self._access_present:
|
|
return self._access_value
|
|
else:
|
|
return None
|
|
|
|
@access.setter
|
|
def access(self, val):
|
|
if val is None:
|
|
del self.access
|
|
return
|
|
self._access_validator.validate_type_only(val)
|
|
self._access_value = val
|
|
self._access_present = True
|
|
|
|
@access.deleter
|
|
def access(self):
|
|
self._access_value = None
|
|
self._access_present = False
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkSettings, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharedLinkSettings(requested_visibility={!r}, link_password={!r}, expires={!r}, audience={!r}, access={!r})'.format(
|
|
self._requested_visibility_value,
|
|
self._link_password_value,
|
|
self._expires_value,
|
|
self._audience_value,
|
|
self._access_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 sharing.SharedLinkSettingsError.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 sharing.SharedLinkSettingsError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharedLinkSettingsError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharingFileAccessError.no_permission: Current user does not
|
|
have sufficient privileges to perform the desired action.
|
|
:ivar sharing.SharingFileAccessError.invalid_file: File specified was not
|
|
found.
|
|
:ivar sharing.SharingFileAccessError.is_folder: A folder can't be shared
|
|
this way. Use folder sharing or a shared link instead.
|
|
:ivar sharing.SharingFileAccessError.inside_public_folder: A file inside a
|
|
public folder can't be shared this way. Use a public link instead.
|
|
:ivar sharing.SharingFileAccessError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharingFileAccessError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.SharingUserError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(SharingUserError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'SharingUserError(%r, %r)' % (self._tag, self._value)
|
|
|
|
SharingUserError_validator = bv.Union(SharingUserError)
|
|
|
|
class TeamMemberInfo(bb.Struct):
|
|
"""
|
|
Information about a team member.
|
|
|
|
:ivar sharing.TeamMemberInfo.team_info: Information about the member's team.
|
|
:ivar sharing.TeamMemberInfo.display_name: The display name of the user.
|
|
:ivar sharing.TeamMemberInfo.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
|
|
"""
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(TeamMemberInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.TransferFolderArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.TransferFolderArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(TransferFolderArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.TransferFolderError.invalid_dropbox_id:
|
|
``TransferFolderArg.to_dropbox_id`` is invalid.
|
|
:ivar sharing.TransferFolderError.new_owner_not_a_member: The new designated
|
|
owner is not currently a member of the shared folder.
|
|
:ivar sharing.TransferFolderError.new_owner_unmounted: The new designated
|
|
owner has not added the folder to their Dropbox.
|
|
:ivar sharing.TransferFolderError.new_owner_email_unverified: The new
|
|
designated owner's e-mail address is unverified.
|
|
:ivar sharing.TransferFolderError.team_folder: This action cannot be
|
|
performed on a team shared folder.
|
|
:ivar sharing.TransferFolderError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(TransferFolderError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'TransferFolderError(%r, %r)' % (self._tag, self._value)
|
|
|
|
TransferFolderError_validator = bv.Union(TransferFolderError)
|
|
|
|
class UnmountFolderArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.UnmountFolderArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnmountFolderArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.UnmountFolderError.no_permission: The current user does not
|
|
have permission to perform this action.
|
|
:ivar sharing.UnmountFolderError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnmountFolderError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'UnmountFolderError(%r, %r)' % (self._tag, self._value)
|
|
|
|
UnmountFolderError_validator = bv.Union(UnmountFolderError)
|
|
|
|
class UnshareFileArg(bb.Struct):
|
|
"""
|
|
Arguments for :meth:`dropbox.dropbox.Dropbox.sharing_unshare_file`.
|
|
|
|
:ivar sharing.UnshareFileArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnshareFileArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnshareFileError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'UnshareFileError(%r, %r)' % (self._tag, self._value)
|
|
|
|
UnshareFileError_validator = bv.Union(UnshareFileError)
|
|
|
|
class UnshareFolderArg(bb.Struct):
|
|
"""
|
|
:ivar sharing.UnshareFolderArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.UnshareFolderArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnshareFolderArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.UnshareFolderError.team_folder: This action cannot be
|
|
performed on a team shared folder.
|
|
:ivar sharing.UnshareFolderError.no_permission: The current user does not
|
|
have permission to perform this action.
|
|
:ivar sharing.UnshareFolderError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UnshareFolderError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UpdateFileMemberArgs, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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(bb.Struct):
|
|
"""
|
|
:ivar sharing.UpdateFolderMemberArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.UpdateFolderMemberArg.member: The member of the shared folder
|
|
to update. Only the ``MemberSelector.dropbox_id`` may be set at this
|
|
time.
|
|
:ivar sharing.UpdateFolderMemberArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UpdateFolderMemberArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 UpdateFolderMemberError.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 sharing.UpdateFolderMemberError.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 sharing.UpdateFolderMemberError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UpdateFolderMemberError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'UpdateFolderMemberError(%r, %r)' % (self._tag, self._value)
|
|
|
|
UpdateFolderMemberError_validator = bv.Union(UpdateFolderMemberError)
|
|
|
|
class UpdateFolderPolicyArg(bb.Struct):
|
|
"""
|
|
If any of the policies are unset, then they retain their current setting.
|
|
|
|
:ivar sharing.UpdateFolderPolicyArg.shared_folder_id: The ID for the shared
|
|
folder.
|
|
:ivar sharing.UpdateFolderPolicyArg.member_policy: Who can be a member of
|
|
this shared folder. Only applicable if the current user is on a team.
|
|
:ivar sharing.UpdateFolderPolicyArg.acl_update_policy: Who can add and
|
|
remove members of this shared folder.
|
|
:ivar sharing.UpdateFolderPolicyArg.viewer_info_policy: Who can
|
|
enable/disable viewer info for this shared folder.
|
|
:ivar sharing.UpdateFolderPolicyArg.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 sharing.UpdateFolderPolicyArg.link_settings: Settings on the link for
|
|
this folder.
|
|
:ivar sharing.UpdateFolderPolicyArg.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UpdateFolderPolicyArg, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.UpdateFolderPolicyError.not_on_team:
|
|
``UpdateFolderPolicyArg.member_policy`` was set even though user is not
|
|
on a team.
|
|
:ivar sharing.UpdateFolderPolicyError.team_policy_disallows_member_policy:
|
|
Team policy is more restrictive than ``ShareFolderArg.member_policy``.
|
|
:ivar sharing.UpdateFolderPolicyError.disallowed_shared_link_policy: The
|
|
current account is not allowed to select the specified
|
|
``ShareFolderArg.shared_link_policy``.
|
|
:ivar sharing.UpdateFolderPolicyError.no_permission: The current user does
|
|
not have permission to perform this action.
|
|
:ivar sharing.UpdateFolderPolicyError.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UpdateFolderPolicyError, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.UserMembershipInfo.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UserMembershipInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.UserFileMembershipInfo.time_last_seen: The UTC timestamp of
|
|
when the user has last seen the content, if they have.
|
|
:ivar sharing.UserFileMembershipInfo.platform_type: The platform on which
|
|
the user has last seen the content, or unknown.
|
|
"""
|
|
|
|
__slots__ = [
|
|
'_time_last_seen_value',
|
|
'_time_last_seen_present',
|
|
'_platform_type_value',
|
|
'_platform_type_present',
|
|
]
|
|
|
|
_has_required_fields = True
|
|
|
|
def __init__(self,
|
|
access_type=None,
|
|
user=None,
|
|
permissions=None,
|
|
initials=None,
|
|
is_inherited=None,
|
|
time_last_seen=None,
|
|
platform_type=None):
|
|
super(UserFileMembershipInfo, self).__init__(access_type,
|
|
user,
|
|
permissions,
|
|
initials,
|
|
is_inherited)
|
|
self._time_last_seen_value = None
|
|
self._time_last_seen_present = False
|
|
self._platform_type_value = None
|
|
self._platform_type_present = False
|
|
if time_last_seen is not None:
|
|
self.time_last_seen = time_last_seen
|
|
if platform_type is not None:
|
|
self.platform_type = platform_type
|
|
|
|
@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
|
|
|
|
@property
|
|
def platform_type(self):
|
|
"""
|
|
The platform on which the user has last seen the content, or unknown.
|
|
|
|
:rtype: seen_state.PlatformType
|
|
"""
|
|
if self._platform_type_present:
|
|
return self._platform_type_value
|
|
else:
|
|
return None
|
|
|
|
@platform_type.setter
|
|
def platform_type(self, val):
|
|
if val is None:
|
|
del self.platform_type
|
|
return
|
|
self._platform_type_validator.validate_type_only(val)
|
|
self._platform_type_value = val
|
|
self._platform_type_present = True
|
|
|
|
@platform_type.deleter
|
|
def platform_type(self):
|
|
self._platform_type_value = None
|
|
self._platform_type_present = False
|
|
|
|
def _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UserFileMembershipInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'UserFileMembershipInfo(access_type={!r}, user={!r}, permissions={!r}, initials={!r}, is_inherited={!r}, time_last_seen={!r}, platform_type={!r})'.format(
|
|
self._access_type_value,
|
|
self._user_value,
|
|
self._permissions_value,
|
|
self._initials_value,
|
|
self._is_inherited_value,
|
|
self._time_last_seen_value,
|
|
self._platform_type_value,
|
|
)
|
|
|
|
UserFileMembershipInfo_validator = bv.Struct(UserFileMembershipInfo)
|
|
|
|
class UserInfo(bb.Struct):
|
|
"""
|
|
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 sharing.UserInfo.account_id: The account ID of the user.
|
|
:ivar sharing.UserInfo.email: Email address of user.
|
|
:ivar sharing.UserInfo.display_name: The display name of the user.
|
|
:ivar sharing.UserInfo.same_team: If the user is in the same team as current
|
|
user.
|
|
:ivar sharing.UserInfo.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',
|
|
'_email_value',
|
|
'_email_present',
|
|
'_display_name_value',
|
|
'_display_name_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,
|
|
email=None,
|
|
display_name=None,
|
|
same_team=None,
|
|
team_member_id=None):
|
|
self._account_id_value = None
|
|
self._account_id_present = False
|
|
self._email_value = None
|
|
self._email_present = False
|
|
self._display_name_value = None
|
|
self._display_name_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 email is not None:
|
|
self.email = email
|
|
if display_name is not None:
|
|
self.display_name = display_name
|
|
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 email(self):
|
|
"""
|
|
Email address of user.
|
|
|
|
:rtype: str
|
|
"""
|
|
if self._email_present:
|
|
return self._email_value
|
|
else:
|
|
raise AttributeError("missing required field 'email'")
|
|
|
|
@email.setter
|
|
def email(self, val):
|
|
val = self._email_validator.validate(val)
|
|
self._email_value = val
|
|
self._email_present = True
|
|
|
|
@email.deleter
|
|
def email(self):
|
|
self._email_value = None
|
|
self._email_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 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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(UserInfo, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'UserInfo(account_id={!r}, email={!r}, display_name={!r}, same_team={!r}, team_member_id={!r})'.format(
|
|
self._account_id_value,
|
|
self._email_value,
|
|
self._display_name_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 sharing.ViewerInfoPolicy.enabled: Viewer information is available on
|
|
this file.
|
|
:ivar sharing.ViewerInfoPolicy.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(ViewerInfoPolicy, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
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 sharing.Visibility.public: Anyone who has received the link can access
|
|
it. No login required.
|
|
:ivar sharing.Visibility.team_only: Only members of the same team can access
|
|
the link. Login is required.
|
|
:ivar sharing.Visibility.password: A link-specific password is required to
|
|
access the link. Login is not required.
|
|
:ivar sharing.Visibility.team_and_password: Only members of the same team
|
|
who have the link-specific password can access the link.
|
|
:ivar sharing.Visibility.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 _process_custom_annotations(self, annotation_type, field_path, processor):
|
|
super(Visibility, self)._process_custom_annotations(annotation_type, field_path, processor)
|
|
|
|
def __repr__(self):
|
|
return 'Visibility(%r, %r)' % (self._tag, self._value)
|
|
|
|
Visibility_validator = bv.Union(Visibility)
|
|
|
|
DropboxId_validator = bv.String(min_length=1)
|
|
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
|
|
AccessInheritance._inherit_validator = bv.Void()
|
|
AccessInheritance._no_inherit_validator = bv.Void()
|
|
AccessInheritance._other_validator = bv.Void()
|
|
AccessInheritance._tagmap = {
|
|
'inherit': AccessInheritance._inherit_validator,
|
|
'no_inherit': AccessInheritance._no_inherit_validator,
|
|
'other': AccessInheritance._other_validator,
|
|
}
|
|
|
|
AccessInheritance.inherit = AccessInheritance('inherit')
|
|
AccessInheritance.no_inherit = AccessInheritance('no_inherit')
|
|
AccessInheritance.other = AccessInheritance('other')
|
|
|
|
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._banned_member_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,
|
|
'banned_member': AddFolderMemberError._banned_member_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.banned_member = AddFolderMemberError('banned_member')
|
|
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.Nullable(SharedLinkAlreadyExistsMetadata_validator)
|
|
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.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._invite_editor_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._create_view_link_validator = bv.Void()
|
|
FileAction._create_edit_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,
|
|
'invite_editor': FileAction._invite_editor_validator,
|
|
'unshare': FileAction._unshare_validator,
|
|
'relinquish_membership': FileAction._relinquish_membership_validator,
|
|
'share_link': FileAction._share_link_validator,
|
|
'create_link': FileAction._create_link_validator,
|
|
'create_view_link': FileAction._create_view_link_validator,
|
|
'create_edit_link': FileAction._create_edit_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.invite_editor = FileAction('invite_editor')
|
|
FileAction.unshare = FileAction('unshare')
|
|
FileAction.relinquish_membership = FileAction('relinquish_membership')
|
|
FileAction.share_link = FileAction('share_link')
|
|
FileAction.create_link = FileAction('create_link')
|
|
FileAction.create_view_link = FileAction('create_view_link')
|
|
FileAction.create_edit_link = FileAction('create_edit_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._set_access_inheritance_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,
|
|
'set_access_inheritance': FolderAction._set_access_inheritance_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.set_access_inheritance = FolderAction('set_access_inheritance')
|
|
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')
|
|
|
|
LinkAccessLevel._viewer_validator = bv.Void()
|
|
LinkAccessLevel._editor_validator = bv.Void()
|
|
LinkAccessLevel._other_validator = bv.Void()
|
|
LinkAccessLevel._tagmap = {
|
|
'viewer': LinkAccessLevel._viewer_validator,
|
|
'editor': LinkAccessLevel._editor_validator,
|
|
'other': LinkAccessLevel._other_validator,
|
|
}
|
|
|
|
LinkAccessLevel.viewer = LinkAccessLevel('viewer')
|
|
LinkAccessLevel.editor = LinkAccessLevel('editor')
|
|
LinkAccessLevel.other = LinkAccessLevel('other')
|
|
|
|
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._no_one_validator = bv.Void()
|
|
LinkAudience._password_validator = bv.Void()
|
|
LinkAudience._members_validator = bv.Void()
|
|
LinkAudience._other_validator = bv.Void()
|
|
LinkAudience._tagmap = {
|
|
'public': LinkAudience._public_validator,
|
|
'team': LinkAudience._team_validator,
|
|
'no_one': LinkAudience._no_one_validator,
|
|
'password': LinkAudience._password_validator,
|
|
'members': LinkAudience._members_validator,
|
|
'other': LinkAudience._other_validator,
|
|
}
|
|
|
|
LinkAudience.public = LinkAudience('public')
|
|
LinkAudience.team = LinkAudience('team')
|
|
LinkAudience.no_one = LinkAudience('no_one')
|
|
LinkAudience.password = LinkAudience('password')
|
|
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._effective_audience_validator = bv.Nullable(LinkAudience_validator)
|
|
LinkPermissions._link_access_level_validator = bv.Nullable(LinkAccessLevel_validator)
|
|
LinkPermissions._all_field_names_ = set([
|
|
'resolved_visibility',
|
|
'requested_visibility',
|
|
'can_revoke',
|
|
'revoke_failure_reason',
|
|
'effective_audience',
|
|
'link_access_level',
|
|
])
|
|
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),
|
|
('effective_audience', LinkPermissions._effective_audience_validator),
|
|
('link_access_level', LinkPermissions._link_access_level_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._too_many_files_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,
|
|
'too_many_files': RemoveFolderMemberError._too_many_files_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.too_many_files = RemoveFolderMemberError('too_many_files')
|
|
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)
|
|
|
|
RequestedLinkAccessLevel._viewer_validator = bv.Void()
|
|
RequestedLinkAccessLevel._editor_validator = bv.Void()
|
|
RequestedLinkAccessLevel._max_validator = bv.Void()
|
|
RequestedLinkAccessLevel._other_validator = bv.Void()
|
|
RequestedLinkAccessLevel._tagmap = {
|
|
'viewer': RequestedLinkAccessLevel._viewer_validator,
|
|
'editor': RequestedLinkAccessLevel._editor_validator,
|
|
'max': RequestedLinkAccessLevel._max_validator,
|
|
'other': RequestedLinkAccessLevel._other_validator,
|
|
}
|
|
|
|
RequestedLinkAccessLevel.viewer = RequestedLinkAccessLevel('viewer')
|
|
RequestedLinkAccessLevel.editor = RequestedLinkAccessLevel('editor')
|
|
RequestedLinkAccessLevel.max = RequestedLinkAccessLevel('max')
|
|
RequestedLinkAccessLevel.other = RequestedLinkAccessLevel('other')
|
|
|
|
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')
|
|
|
|
SetAccessInheritanceArg._access_inheritance_validator = AccessInheritance_validator
|
|
SetAccessInheritanceArg._shared_folder_id_validator = common.SharedFolderId_validator
|
|
SetAccessInheritanceArg._all_field_names_ = set([
|
|
'access_inheritance',
|
|
'shared_folder_id',
|
|
])
|
|
SetAccessInheritanceArg._all_fields_ = [
|
|
('access_inheritance', SetAccessInheritanceArg._access_inheritance_validator),
|
|
('shared_folder_id', SetAccessInheritanceArg._shared_folder_id_validator),
|
|
]
|
|
|
|
SetAccessInheritanceError._access_error_validator = SharedFolderAccessError_validator
|
|
SetAccessInheritanceError._no_permission_validator = bv.Void()
|
|
SetAccessInheritanceError._other_validator = bv.Void()
|
|
SetAccessInheritanceError._tagmap = {
|
|
'access_error': SetAccessInheritanceError._access_error_validator,
|
|
'no_permission': SetAccessInheritanceError._no_permission_validator,
|
|
'other': SetAccessInheritanceError._other_validator,
|
|
}
|
|
|
|
SetAccessInheritanceError.no_permission = SetAccessInheritanceError('no_permission')
|
|
SetAccessInheritanceError.other = SetAccessInheritanceError('other')
|
|
|
|
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._access_inheritance_validator = AccessInheritance_validator
|
|
ShareFolderArgBase._all_field_names_ = set([
|
|
'acl_update_policy',
|
|
'force_async',
|
|
'member_policy',
|
|
'path',
|
|
'shared_link_policy',
|
|
'viewer_info_policy',
|
|
'access_inheritance',
|
|
])
|
|
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),
|
|
('access_inheritance', ShareFolderArgBase._access_inheritance_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 = files.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._access_inheritance_validator = AccessInheritance_validator
|
|
SharedFolderMetadata._all_field_names_ = SharedFolderMetadataBase._all_field_names_.union(set([
|
|
'link_metadata',
|
|
'name',
|
|
'permissions',
|
|
'policy',
|
|
'preview_url',
|
|
'shared_folder_id',
|
|
'time_invited',
|
|
'access_inheritance',
|
|
]))
|
|
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),
|
|
('access_inheritance', SharedFolderMetadata._access_inheritance_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')
|
|
|
|
SharedLinkAlreadyExistsMetadata._metadata_validator = SharedLinkMetadata_validator
|
|
SharedLinkAlreadyExistsMetadata._other_validator = bv.Void()
|
|
SharedLinkAlreadyExistsMetadata._tagmap = {
|
|
'metadata': SharedLinkAlreadyExistsMetadata._metadata_validator,
|
|
'other': SharedLinkAlreadyExistsMetadata._other_validator,
|
|
}
|
|
|
|
SharedLinkAlreadyExistsMetadata.other = SharedLinkAlreadyExistsMetadata('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._audience_validator = bv.Nullable(LinkAudience_validator)
|
|
SharedLinkSettings._access_validator = bv.Nullable(RequestedLinkAccessLevel_validator)
|
|
SharedLinkSettings._all_field_names_ = set([
|
|
'requested_visibility',
|
|
'link_password',
|
|
'expires',
|
|
'audience',
|
|
'access',
|
|
])
|
|
SharedLinkSettings._all_fields_ = [
|
|
('requested_visibility', SharedLinkSettings._requested_visibility_validator),
|
|
('link_password', SharedLinkSettings._link_password_validator),
|
|
('expires', SharedLinkSettings._expires_validator),
|
|
('audience', SharedLinkSettings._audience_validator),
|
|
('access', SharedLinkSettings._access_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._platform_type_validator = bv.Nullable(seen_state.PlatformType_validator)
|
|
UserFileMembershipInfo._all_field_names_ = UserMembershipInfo._all_field_names_.union(set([
|
|
'time_last_seen',
|
|
'platform_type',
|
|
]))
|
|
UserFileMembershipInfo._all_fields_ = UserMembershipInfo._all_fields_ + [
|
|
('time_last_seen', UserFileMembershipInfo._time_last_seen_validator),
|
|
('platform_type', UserFileMembershipInfo._platform_type_validator),
|
|
]
|
|
|
|
UserInfo._account_id_validator = users_common.AccountId_validator
|
|
UserInfo._email_validator = bv.String()
|
|
UserInfo._display_name_validator = bv.String()
|
|
UserInfo._same_team_validator = bv.Boolean()
|
|
UserInfo._team_member_id_validator = bv.Nullable(bv.String())
|
|
UserInfo._all_field_names_ = set([
|
|
'account_id',
|
|
'email',
|
|
'display_name',
|
|
'same_team',
|
|
'team_member_id',
|
|
])
|
|
UserInfo._all_fields_ = [
|
|
('account_id', UserInfo._account_id_validator),
|
|
('email', UserInfo._email_validator),
|
|
('display_name', UserInfo._display_name_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',
|
|
1,
|
|
False,
|
|
AddFileMemberArgs_validator,
|
|
bv.List(FileMemberActionResult_validator),
|
|
AddFileMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
add_folder_member = bb.Route(
|
|
'add_folder_member',
|
|
1,
|
|
False,
|
|
AddFolderMemberArg_validator,
|
|
bv.Void(),
|
|
AddFolderMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
change_file_member_access = bb.Route(
|
|
'change_file_member_access',
|
|
1,
|
|
True,
|
|
ChangeFileMemberAccessArgs_validator,
|
|
FileMemberActionResult_validator,
|
|
FileMemberActionError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
check_job_status = bb.Route(
|
|
'check_job_status',
|
|
1,
|
|
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',
|
|
1,
|
|
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',
|
|
1,
|
|
False,
|
|
async_.PollArg_validator,
|
|
ShareFolderJobStatus_validator,
|
|
async_.PollError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
create_shared_link = bb.Route(
|
|
'create_shared_link',
|
|
1,
|
|
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',
|
|
1,
|
|
False,
|
|
CreateSharedLinkWithSettingsArg_validator,
|
|
SharedLinkMetadata_validator,
|
|
CreateSharedLinkWithSettingsError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
get_file_metadata = bb.Route(
|
|
'get_file_metadata',
|
|
1,
|
|
False,
|
|
GetFileMetadataArg_validator,
|
|
SharedFileMetadata_validator,
|
|
GetFileMetadataError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
get_file_metadata_batch = bb.Route(
|
|
'get_file_metadata/batch',
|
|
1,
|
|
False,
|
|
GetFileMetadataBatchArg_validator,
|
|
bv.List(GetFileMetadataBatchResult_validator),
|
|
SharingUserError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
get_folder_metadata = bb.Route(
|
|
'get_folder_metadata',
|
|
1,
|
|
False,
|
|
GetMetadataArgs_validator,
|
|
SharedFolderMetadata_validator,
|
|
SharedFolderAccessError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
get_shared_link_file = bb.Route(
|
|
'get_shared_link_file',
|
|
1,
|
|
False,
|
|
GetSharedLinkFileArg_validator,
|
|
SharedLinkMetadata_validator,
|
|
GetSharedLinkFileError_validator,
|
|
{'host': u'content',
|
|
'style': u'download'},
|
|
)
|
|
get_shared_link_metadata = bb.Route(
|
|
'get_shared_link_metadata',
|
|
1,
|
|
False,
|
|
GetSharedLinkMetadataArg_validator,
|
|
SharedLinkMetadata_validator,
|
|
SharedLinkError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
get_shared_links = bb.Route(
|
|
'get_shared_links',
|
|
1,
|
|
True,
|
|
GetSharedLinksArg_validator,
|
|
GetSharedLinksResult_validator,
|
|
GetSharedLinksError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_file_members = bb.Route(
|
|
'list_file_members',
|
|
1,
|
|
False,
|
|
ListFileMembersArg_validator,
|
|
SharedFileMembers_validator,
|
|
ListFileMembersError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_file_members_batch = bb.Route(
|
|
'list_file_members/batch',
|
|
1,
|
|
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',
|
|
1,
|
|
False,
|
|
ListFileMembersContinueArg_validator,
|
|
SharedFileMembers_validator,
|
|
ListFileMembersContinueError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_folder_members = bb.Route(
|
|
'list_folder_members',
|
|
1,
|
|
False,
|
|
ListFolderMembersArgs_validator,
|
|
SharedFolderMembers_validator,
|
|
SharedFolderAccessError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_folder_members_continue = bb.Route(
|
|
'list_folder_members/continue',
|
|
1,
|
|
False,
|
|
ListFolderMembersContinueArg_validator,
|
|
SharedFolderMembers_validator,
|
|
ListFolderMembersContinueError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_folders = bb.Route(
|
|
'list_folders',
|
|
1,
|
|
False,
|
|
ListFoldersArgs_validator,
|
|
ListFoldersResult_validator,
|
|
bv.Void(),
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_folders_continue = bb.Route(
|
|
'list_folders/continue',
|
|
1,
|
|
False,
|
|
ListFoldersContinueArg_validator,
|
|
ListFoldersResult_validator,
|
|
ListFoldersContinueError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_mountable_folders = bb.Route(
|
|
'list_mountable_folders',
|
|
1,
|
|
False,
|
|
ListFoldersArgs_validator,
|
|
ListFoldersResult_validator,
|
|
bv.Void(),
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_mountable_folders_continue = bb.Route(
|
|
'list_mountable_folders/continue',
|
|
1,
|
|
False,
|
|
ListFoldersContinueArg_validator,
|
|
ListFoldersResult_validator,
|
|
ListFoldersContinueError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_received_files = bb.Route(
|
|
'list_received_files',
|
|
1,
|
|
False,
|
|
ListFilesArg_validator,
|
|
ListFilesResult_validator,
|
|
SharingUserError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_received_files_continue = bb.Route(
|
|
'list_received_files/continue',
|
|
1,
|
|
False,
|
|
ListFilesContinueArg_validator,
|
|
ListFilesResult_validator,
|
|
ListFilesContinueError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
list_shared_links = bb.Route(
|
|
'list_shared_links',
|
|
1,
|
|
False,
|
|
ListSharedLinksArg_validator,
|
|
ListSharedLinksResult_validator,
|
|
ListSharedLinksError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
modify_shared_link_settings = bb.Route(
|
|
'modify_shared_link_settings',
|
|
1,
|
|
False,
|
|
ModifySharedLinkSettingsArgs_validator,
|
|
SharedLinkMetadata_validator,
|
|
ModifySharedLinkSettingsError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
mount_folder = bb.Route(
|
|
'mount_folder',
|
|
1,
|
|
False,
|
|
MountFolderArg_validator,
|
|
SharedFolderMetadata_validator,
|
|
MountFolderError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
relinquish_file_membership = bb.Route(
|
|
'relinquish_file_membership',
|
|
1,
|
|
False,
|
|
RelinquishFileMembershipArg_validator,
|
|
bv.Void(),
|
|
RelinquishFileMembershipError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
relinquish_folder_membership = bb.Route(
|
|
'relinquish_folder_membership',
|
|
1,
|
|
False,
|
|
RelinquishFolderMembershipArg_validator,
|
|
async_.LaunchEmptyResult_validator,
|
|
RelinquishFolderMembershipError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
remove_file_member = bb.Route(
|
|
'remove_file_member',
|
|
1,
|
|
True,
|
|
RemoveFileMemberArg_validator,
|
|
FileMemberActionIndividualResult_validator,
|
|
RemoveFileMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
remove_file_member_2 = bb.Route(
|
|
'remove_file_member_2',
|
|
1,
|
|
False,
|
|
RemoveFileMemberArg_validator,
|
|
FileMemberRemoveActionResult_validator,
|
|
RemoveFileMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
remove_folder_member = bb.Route(
|
|
'remove_folder_member',
|
|
1,
|
|
False,
|
|
RemoveFolderMemberArg_validator,
|
|
async_.LaunchResultBase_validator,
|
|
RemoveFolderMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
revoke_shared_link = bb.Route(
|
|
'revoke_shared_link',
|
|
1,
|
|
False,
|
|
RevokeSharedLinkArg_validator,
|
|
bv.Void(),
|
|
RevokeSharedLinkError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
set_access_inheritance = bb.Route(
|
|
'set_access_inheritance',
|
|
1,
|
|
False,
|
|
SetAccessInheritanceArg_validator,
|
|
ShareFolderLaunch_validator,
|
|
SetAccessInheritanceError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
share_folder = bb.Route(
|
|
'share_folder',
|
|
1,
|
|
False,
|
|
ShareFolderArg_validator,
|
|
ShareFolderLaunch_validator,
|
|
ShareFolderError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
transfer_folder = bb.Route(
|
|
'transfer_folder',
|
|
1,
|
|
False,
|
|
TransferFolderArg_validator,
|
|
bv.Void(),
|
|
TransferFolderError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
unmount_folder = bb.Route(
|
|
'unmount_folder',
|
|
1,
|
|
False,
|
|
UnmountFolderArg_validator,
|
|
bv.Void(),
|
|
UnmountFolderError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
unshare_file = bb.Route(
|
|
'unshare_file',
|
|
1,
|
|
False,
|
|
UnshareFileArg_validator,
|
|
bv.Void(),
|
|
UnshareFileError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
unshare_folder = bb.Route(
|
|
'unshare_folder',
|
|
1,
|
|
False,
|
|
UnshareFolderArg_validator,
|
|
async_.LaunchEmptyResult_validator,
|
|
UnshareFolderError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
update_file_member = bb.Route(
|
|
'update_file_member',
|
|
1,
|
|
False,
|
|
UpdateFileMemberArgs_validator,
|
|
MemberAccessLevelResult_validator,
|
|
FileMemberActionError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
update_folder_member = bb.Route(
|
|
'update_folder_member',
|
|
1,
|
|
False,
|
|
UpdateFolderMemberArg_validator,
|
|
MemberAccessLevelResult_validator,
|
|
UpdateFolderMemberError_validator,
|
|
{'host': u'api',
|
|
'style': u'rpc'},
|
|
)
|
|
update_folder_policy = bb.Route(
|
|
'update_folder_policy',
|
|
1,
|
|
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,
|
|
'set_access_inheritance': set_access_inheritance,
|
|
'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,
|
|
}
|
|
|