xbmcbackup/resources/lib/dropbox/files.py
Rob af1ae52e69
Merge Dropbox V2 (#123)
* pulled all dropbox v1 code, added v2. fixed authorization flow
2017-12-03 17:32:21 -06:00

10782 lines
314 KiB
Python

# -*- coding: utf-8 -*-
# Auto-generated by Stone, do not modify.
# flake8: noqa
# pylint: skip-file
"""
This namespace contains endpoints and data types for basic file operations.
"""
try:
from . import stone_validators as bv
from . import stone_base as bb
except (SystemError, ValueError):
# Catch errors raised when importing a relative module when not in a package.
# This makes testing this file directly (outside of a package) easier.
import stone_validators as bv
import stone_base as bb
try:
from . import (
async,
common,
file_properties,
users_common,
)
except (SystemError, ValueError):
import async
import common
import file_properties
import users_common
class GetMetadataArg(object):
"""
:ivar path: The path of a file or folder on Dropbox.
:ivar include_media_info: If true, ``FileMetadata.media_info`` is set for
photo and video.
:ivar include_deleted: If true, :class:`DeletedMetadata` will be returned
for deleted file or folder, otherwise ``LookupError.not_found`` will be
returned.
:ivar include_has_explicit_shared_members: If true, the results will include
a flag for each file indicating whether or not that file has any
explicit members.
"""
__slots__ = [
'_path_value',
'_path_present',
'_include_media_info_value',
'_include_media_info_present',
'_include_deleted_value',
'_include_deleted_present',
'_include_has_explicit_shared_members_value',
'_include_has_explicit_shared_members_present',
]
_has_required_fields = True
def __init__(self,
path=None,
include_media_info=None,
include_deleted=None,
include_has_explicit_shared_members=None):
self._path_value = None
self._path_present = False
self._include_media_info_value = None
self._include_media_info_present = False
self._include_deleted_value = None
self._include_deleted_present = False
self._include_has_explicit_shared_members_value = None
self._include_has_explicit_shared_members_present = False
if path is not None:
self.path = path
if include_media_info is not None:
self.include_media_info = include_media_info
if include_deleted is not None:
self.include_deleted = include_deleted
if include_has_explicit_shared_members is not None:
self.include_has_explicit_shared_members = include_has_explicit_shared_members
@property
def path(self):
"""
The path of a file or folder on 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
@property
def include_media_info(self):
"""
If true, ``FileMetadata.media_info`` is set for photo and video.
:rtype: bool
"""
if self._include_media_info_present:
return self._include_media_info_value
else:
return False
@include_media_info.setter
def include_media_info(self, val):
val = self._include_media_info_validator.validate(val)
self._include_media_info_value = val
self._include_media_info_present = True
@include_media_info.deleter
def include_media_info(self):
self._include_media_info_value = None
self._include_media_info_present = False
@property
def include_deleted(self):
"""
If true, :class:`DeletedMetadata` will be returned for deleted file or
folder, otherwise ``LookupError.not_found`` will be returned.
:rtype: bool
"""
if self._include_deleted_present:
return self._include_deleted_value
else:
return False
@include_deleted.setter
def include_deleted(self, val):
val = self._include_deleted_validator.validate(val)
self._include_deleted_value = val
self._include_deleted_present = True
@include_deleted.deleter
def include_deleted(self):
self._include_deleted_value = None
self._include_deleted_present = False
@property
def include_has_explicit_shared_members(self):
"""
If true, the results will include a flag for each file indicating
whether or not that file has any explicit members.
:rtype: bool
"""
if self._include_has_explicit_shared_members_present:
return self._include_has_explicit_shared_members_value
else:
return False
@include_has_explicit_shared_members.setter
def include_has_explicit_shared_members(self, val):
val = self._include_has_explicit_shared_members_validator.validate(val)
self._include_has_explicit_shared_members_value = val
self._include_has_explicit_shared_members_present = True
@include_has_explicit_shared_members.deleter
def include_has_explicit_shared_members(self):
self._include_has_explicit_shared_members_value = None
self._include_has_explicit_shared_members_present = False
def __repr__(self):
return 'GetMetadataArg(path={!r}, include_media_info={!r}, include_deleted={!r}, include_has_explicit_shared_members={!r})'.format(
self._path_value,
self._include_media_info_value,
self._include_deleted_value,
self._include_has_explicit_shared_members_value,
)
GetMetadataArg_validator = bv.Struct(GetMetadataArg)
class AlphaGetMetadataArg(GetMetadataArg):
"""
:ivar include_property_templates: If set to a valid list of template IDs,
``FileMetadata.property_groups`` is set for files with custom
properties.
"""
__slots__ = [
'_include_property_templates_value',
'_include_property_templates_present',
]
_has_required_fields = True
def __init__(self,
path=None,
include_media_info=None,
include_deleted=None,
include_has_explicit_shared_members=None,
include_property_templates=None):
super(AlphaGetMetadataArg, self).__init__(path,
include_media_info,
include_deleted,
include_has_explicit_shared_members)
self._include_property_templates_value = None
self._include_property_templates_present = False
if include_property_templates is not None:
self.include_property_templates = include_property_templates
@property
def include_property_templates(self):
"""
If set to a valid list of template IDs, ``FileMetadata.property_groups``
is set for files with custom properties.
:rtype: list of [str]
"""
if self._include_property_templates_present:
return self._include_property_templates_value
else:
return None
@include_property_templates.setter
def include_property_templates(self, val):
if val is None:
del self.include_property_templates
return
val = self._include_property_templates_validator.validate(val)
self._include_property_templates_value = val
self._include_property_templates_present = True
@include_property_templates.deleter
def include_property_templates(self):
self._include_property_templates_value = None
self._include_property_templates_present = False
def __repr__(self):
return 'AlphaGetMetadataArg(path={!r}, include_media_info={!r}, include_deleted={!r}, include_has_explicit_shared_members={!r}, include_property_templates={!r})'.format(
self._path_value,
self._include_media_info_value,
self._include_deleted_value,
self._include_has_explicit_shared_members_value,
self._include_property_templates_value,
)
AlphaGetMetadataArg_validator = bv.Struct(AlphaGetMetadataArg)
class GetMetadataError(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 = None
@classmethod
def path(cls, val):
"""
Create an instance of this class set to the ``path`` tag with value
``val``.
:param LookupError val:
:rtype: GetMetadataError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def get_path(self):
"""
Only call this if :meth:`is_path` is true.
:rtype: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'GetMetadataError(%r, %r)' % (self._tag, self._value)
GetMetadataError_validator = bv.Union(GetMetadataError)
class AlphaGetMetadataError(GetMetadataError):
"""
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 properties_error(cls, val):
"""
Create an instance of this class set to the ``properties_error`` tag
with value ``val``.
:param file_properties.LookUpPropertiesError_validator val:
:rtype: AlphaGetMetadataError
"""
return cls('properties_error', val)
def is_properties_error(self):
"""
Check if the union tag is ``properties_error``.
:rtype: bool
"""
return self._tag == 'properties_error'
def get_properties_error(self):
"""
Only call this if :meth:`is_properties_error` is true.
:rtype: file_properties.LookUpPropertiesError_validator
"""
if not self.is_properties_error():
raise AttributeError("tag 'properties_error' not set")
return self._value
def __repr__(self):
return 'AlphaGetMetadataError(%r, %r)' % (self._tag, self._value)
AlphaGetMetadataError_validator = bv.Union(AlphaGetMetadataError)
class CommitInfo(object):
"""
:ivar path: Path in the user's Dropbox to save the file.
:ivar mode: Selects what to do if the file already exists.
:ivar autorename: If there's a conflict, as determined by ``mode``, have the
Dropbox server try to autorename the file to avoid conflict.
:ivar client_modified: The value to store as the ``client_modified``
timestamp. Dropbox automatically records the time at which the file was
written to the Dropbox servers. It can also record an additional
timestamp, provided by Dropbox desktop clients, mobile clients, and API
apps of when the file was actually created or modified.
:ivar mute: Normally, users are made aware of any file modifications in
their Dropbox account via notifications in the client software. If
``True``, this tells the clients that this modification shouldn't result
in a user notification.
"""
__slots__ = [
'_path_value',
'_path_present',
'_mode_value',
'_mode_present',
'_autorename_value',
'_autorename_present',
'_client_modified_value',
'_client_modified_present',
'_mute_value',
'_mute_present',
]
_has_required_fields = True
def __init__(self,
path=None,
mode=None,
autorename=None,
client_modified=None,
mute=None):
self._path_value = None
self._path_present = False
self._mode_value = None
self._mode_present = False
self._autorename_value = None
self._autorename_present = False
self._client_modified_value = None
self._client_modified_present = False
self._mute_value = None
self._mute_present = False
if path is not None:
self.path = path
if mode is not None:
self.mode = mode
if autorename is not None:
self.autorename = autorename
if client_modified is not None:
self.client_modified = client_modified
if mute is not None:
self.mute = mute
@property
def path(self):
"""
Path in the user's Dropbox to save the file.
: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 mode(self):
"""
Selects what to do if the file already exists.
:rtype: WriteMode
"""
if self._mode_present:
return self._mode_value
else:
return WriteMode.add
@mode.setter
def mode(self, val):
self._mode_validator.validate_type_only(val)
self._mode_value = val
self._mode_present = True
@mode.deleter
def mode(self):
self._mode_value = None
self._mode_present = False
@property
def autorename(self):
"""
If there's a conflict, as determined by ``mode``, have the Dropbox
server try to autorename the file to avoid conflict.
:rtype: bool
"""
if self._autorename_present:
return self._autorename_value
else:
return False
@autorename.setter
def autorename(self, val):
val = self._autorename_validator.validate(val)
self._autorename_value = val
self._autorename_present = True
@autorename.deleter
def autorename(self):
self._autorename_value = None
self._autorename_present = False
@property
def client_modified(self):
"""
The value to store as the ``client_modified`` timestamp. Dropbox
automatically records the time at which the file was written to the
Dropbox servers. It can also record an additional timestamp, provided by
Dropbox desktop clients, mobile clients, and API apps of when the file
was actually created or modified.
:rtype: datetime.datetime
"""
if self._client_modified_present:
return self._client_modified_value
else:
return None
@client_modified.setter
def client_modified(self, val):
if val is None:
del self.client_modified
return
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 mute(self):
"""
Normally, users are made aware of any file modifications in their
Dropbox account via notifications in the client software. If ``True``,
this tells the clients that this modification shouldn't result in a user
notification.
:rtype: bool
"""
if self._mute_present:
return self._mute_value
else:
return False
@mute.setter
def mute(self, val):
val = self._mute_validator.validate(val)
self._mute_value = val
self._mute_present = True
@mute.deleter
def mute(self):
self._mute_value = None
self._mute_present = False
def __repr__(self):
return 'CommitInfo(path={!r}, mode={!r}, autorename={!r}, client_modified={!r}, mute={!r})'.format(
self._path_value,
self._mode_value,
self._autorename_value,
self._client_modified_value,
self._mute_value,
)
CommitInfo_validator = bv.Struct(CommitInfo)
class CommitInfoWithProperties(CommitInfo):
"""
:ivar property_groups: List of custom properties to add to file.
"""
__slots__ = [
'_property_groups_value',
'_property_groups_present',
]
_has_required_fields = True
def __init__(self,
path=None,
mode=None,
autorename=None,
client_modified=None,
mute=None,
property_groups=None):
super(CommitInfoWithProperties, self).__init__(path,
mode,
autorename,
client_modified,
mute)
self._property_groups_value = None
self._property_groups_present = False
if property_groups is not None:
self.property_groups = property_groups
@property
def property_groups(self):
"""
List of custom properties to add to file.
:rtype: list of [file_properties.PropertyGroup_validator]
"""
if self._property_groups_present:
return self._property_groups_value
else:
return None
@property_groups.setter
def property_groups(self, val):
if val is None:
del self.property_groups
return
val = self._property_groups_validator.validate(val)
self._property_groups_value = val
self._property_groups_present = True
@property_groups.deleter
def property_groups(self):
self._property_groups_value = None
self._property_groups_present = False
def __repr__(self):
return 'CommitInfoWithProperties(path={!r}, mode={!r}, autorename={!r}, client_modified={!r}, mute={!r}, property_groups={!r})'.format(
self._path_value,
self._mode_value,
self._autorename_value,
self._client_modified_value,
self._mute_value,
self._property_groups_value,
)
CommitInfoWithProperties_validator = bv.Struct(CommitInfoWithProperties)
class CreateFolderArg(object):
"""
:ivar path: Path in the user's Dropbox to create.
:ivar autorename: If there's a conflict, have the Dropbox server try to
autorename the folder to avoid the conflict.
"""
__slots__ = [
'_path_value',
'_path_present',
'_autorename_value',
'_autorename_present',
]
_has_required_fields = True
def __init__(self,
path=None,
autorename=None):
self._path_value = None
self._path_present = False
self._autorename_value = None
self._autorename_present = False
if path is not None:
self.path = path
if autorename is not None:
self.autorename = autorename
@property
def path(self):
"""
Path in the user's Dropbox to create.
: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 autorename(self):
"""
If there's a conflict, have the Dropbox server try to autorename the
folder to avoid the conflict.
:rtype: bool
"""
if self._autorename_present:
return self._autorename_value
else:
return False
@autorename.setter
def autorename(self, val):
val = self._autorename_validator.validate(val)
self._autorename_value = val
self._autorename_present = True
@autorename.deleter
def autorename(self):
self._autorename_value = None
self._autorename_present = False
def __repr__(self):
return 'CreateFolderArg(path={!r}, autorename={!r})'.format(
self._path_value,
self._autorename_value,
)
CreateFolderArg_validator = bv.Struct(CreateFolderArg)
class CreateFolderError(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 = None
@classmethod
def path(cls, val):
"""
Create an instance of this class set to the ``path`` tag with value
``val``.
:param WriteError val:
:rtype: CreateFolderError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def get_path(self):
"""
Only call this if :meth:`is_path` is true.
:rtype: WriteError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'CreateFolderError(%r, %r)' % (self._tag, self._value)
CreateFolderError_validator = bv.Union(CreateFolderError)
class FileOpsResult(object):
__slots__ = [
]
_has_required_fields = False
def __init__(self):
pass
def __repr__(self):
return 'FileOpsResult()'
FileOpsResult_validator = bv.Struct(FileOpsResult)
class CreateFolderResult(FileOpsResult):
"""
:ivar metadata: Metadata of the created folder.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
super(CreateFolderResult, self).__init__()
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
Metadata of the created folder.
:rtype: FolderMetadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'CreateFolderResult(metadata={!r})'.format(
self._metadata_value,
)
CreateFolderResult_validator = bv.Struct(CreateFolderResult)
class DeleteArg(object):
"""
:ivar path: Path in the user's Dropbox to delete.
"""
__slots__ = [
'_path_value',
'_path_present',
]
_has_required_fields = True
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):
"""
Path in the user's Dropbox to delete.
:rtype: str
"""
if self._path_present:
return self._path_value
else:
raise AttributeError("missing required field 'path'")
@path.setter
def path(self, val):
val = self._path_validator.validate(val)
self._path_value = val
self._path_present = True
@path.deleter
def path(self):
self._path_value = None
self._path_present = False
def __repr__(self):
return 'DeleteArg(path={!r})'.format(
self._path_value,
)
DeleteArg_validator = bv.Struct(DeleteArg)
class DeleteBatchArg(object):
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
:rtype: list of [DeleteArg]
"""
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
def __repr__(self):
return 'DeleteBatchArg(entries={!r})'.format(
self._entries_value,
)
DeleteBatchArg_validator = bv.Struct(DeleteBatchArg)
class DeleteBatchError(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 too_many_write_operations: Use
``DeleteError.too_many_write_operations``.
:meth:`dropbox.dropbox.Dropbox.files_delete_batch` now provides smaller
granularity about which entry has failed because of this.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
too_many_write_operations = None
# Attribute is overwritten below the class definition
other = None
def is_too_many_write_operations(self):
"""
Check if the union tag is ``too_many_write_operations``.
:rtype: bool
"""
return self._tag == 'too_many_write_operations'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def __repr__(self):
return 'DeleteBatchError(%r, %r)' % (self._tag, self._value)
DeleteBatchError_validator = bv.Union(DeleteBatchError)
class DeleteBatchJobStatus(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 DeleteBatchResult complete: The batch delete has finished.
:ivar DeleteBatchError failed: The batch delete has failed.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
other = None
@classmethod
def complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param DeleteBatchResult val:
:rtype: DeleteBatchJobStatus
"""
return cls('complete', val)
@classmethod
def failed(cls, val):
"""
Create an instance of this class set to the ``failed`` tag with value
``val``.
:param DeleteBatchError val:
:rtype: DeleteBatchJobStatus
"""
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 is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_complete(self):
"""
The batch delete has finished.
Only call this if :meth:`is_complete` is true.
:rtype: DeleteBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def get_failed(self):
"""
The batch delete has failed.
Only call this if :meth:`is_failed` is true.
:rtype: DeleteBatchError
"""
if not self.is_failed():
raise AttributeError("tag 'failed' not set")
return self._value
def __repr__(self):
return 'DeleteBatchJobStatus(%r, %r)' % (self._tag, self._value)
DeleteBatchJobStatus_validator = bv.Union(DeleteBatchJobStatus)
class DeleteBatchLaunch(async.LaunchResultBase):
"""
Result returned by :meth:`dropbox.dropbox.Dropbox.files_delete_batch` that
may either launch an asynchronous job or complete synchronously.
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 complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param DeleteBatchResult val:
:rtype: DeleteBatchLaunch
"""
return cls('complete', val)
def is_complete(self):
"""
Check if the union tag is ``complete``.
:rtype: bool
"""
return self._tag == 'complete'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_complete(self):
"""
Only call this if :meth:`is_complete` is true.
:rtype: DeleteBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def __repr__(self):
return 'DeleteBatchLaunch(%r, %r)' % (self._tag, self._value)
DeleteBatchLaunch_validator = bv.Union(DeleteBatchLaunch)
class DeleteBatchResult(FileOpsResult):
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
super(DeleteBatchResult, self).__init__()
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
:rtype: list of [DeleteBatchResultEntry]
"""
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
def __repr__(self):
return 'DeleteBatchResult(entries={!r})'.format(
self._entries_value,
)
DeleteBatchResult_validator = bv.Struct(DeleteBatchResult)
class DeleteBatchResultData(object):
"""
:ivar metadata: Metadata of the deleted object.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
Metadata of the deleted object.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'DeleteBatchResultData(metadata={!r})'.format(
self._metadata_value,
)
DeleteBatchResultData_validator = bv.Struct(DeleteBatchResultData)
class DeleteBatchResultEntry(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 = None
@classmethod
def success(cls, val):
"""
Create an instance of this class set to the ``success`` tag with value
``val``.
:param DeleteBatchResultData val:
:rtype: DeleteBatchResultEntry
"""
return cls('success', val)
@classmethod
def failure(cls, val):
"""
Create an instance of this class set to the ``failure`` tag with value
``val``.
:param DeleteError val:
:rtype: DeleteBatchResultEntry
"""
return cls('failure', val)
def is_success(self):
"""
Check if the union tag is ``success``.
:rtype: bool
"""
return self._tag == 'success'
def is_failure(self):
"""
Check if the union tag is ``failure``.
:rtype: bool
"""
return self._tag == 'failure'
def get_success(self):
"""
Only call this if :meth:`is_success` is true.
:rtype: DeleteBatchResultData
"""
if not self.is_success():
raise AttributeError("tag 'success' not set")
return self._value
def get_failure(self):
"""
Only call this if :meth:`is_failure` is true.
:rtype: DeleteError
"""
if not self.is_failure():
raise AttributeError("tag 'failure' not set")
return self._value
def __repr__(self):
return 'DeleteBatchResultEntry(%r, %r)' % (self._tag, self._value)
DeleteBatchResultEntry_validator = bv.Union(DeleteBatchResultEntry)
class DeleteError(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 too_many_write_operations: There are too many write operations in
user's Dropbox. Please retry this request.
:ivar too_many_files: There are too many files in one request. Please retry
with fewer files.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
too_many_write_operations = None
# Attribute is overwritten below the class definition
too_many_files = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def path_lookup(cls, val):
"""
Create an instance of this class set to the ``path_lookup`` tag with
value ``val``.
:param LookupError val:
:rtype: DeleteError
"""
return cls('path_lookup', val)
@classmethod
def path_write(cls, val):
"""
Create an instance of this class set to the ``path_write`` tag with
value ``val``.
:param WriteError val:
:rtype: DeleteError
"""
return cls('path_write', val)
def is_path_lookup(self):
"""
Check if the union tag is ``path_lookup``.
:rtype: bool
"""
return self._tag == 'path_lookup'
def is_path_write(self):
"""
Check if the union tag is ``path_write``.
:rtype: bool
"""
return self._tag == 'path_write'
def is_too_many_write_operations(self):
"""
Check if the union tag is ``too_many_write_operations``.
:rtype: bool
"""
return self._tag == 'too_many_write_operations'
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_path_lookup(self):
"""
Only call this if :meth:`is_path_lookup` is true.
:rtype: LookupError
"""
if not self.is_path_lookup():
raise AttributeError("tag 'path_lookup' not set")
return self._value
def get_path_write(self):
"""
Only call this if :meth:`is_path_write` is true.
:rtype: WriteError
"""
if not self.is_path_write():
raise AttributeError("tag 'path_write' not set")
return self._value
def __repr__(self):
return 'DeleteError(%r, %r)' % (self._tag, self._value)
DeleteError_validator = bv.Union(DeleteError)
class DeleteResult(FileOpsResult):
"""
:ivar metadata: Metadata of the deleted object.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
super(DeleteResult, self).__init__()
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
Metadata of the deleted object.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'DeleteResult(metadata={!r})'.format(
self._metadata_value,
)
DeleteResult_validator = bv.Struct(DeleteResult)
class Metadata(object):
"""
Metadata for a file or folder.
:ivar name: The last component of the path (including extension). This never
contains a slash.
:ivar path_lower: The lowercased full path in the user's Dropbox. This
always starts with a slash. This field will be null if the file or
folder is not mounted.
:ivar path_display: The cased path to be used for display purposes only. In
rare instances the casing will not correctly match the user's
filesystem, but this behavior will match the path provided in the Core
API v1, and at least the last path component will have the correct
casing. Changes to only the casing of paths won't be returned by
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue`. This field
will be null if the file or folder is not mounted.
:ivar parent_shared_folder_id: Please use
``FileSharingInfo.parent_shared_folder_id`` or
``FolderSharingInfo.parent_shared_folder_id`` instead.
"""
__slots__ = [
'_name_value',
'_name_present',
'_path_lower_value',
'_path_lower_present',
'_path_display_value',
'_path_display_present',
'_parent_shared_folder_id_value',
'_parent_shared_folder_id_present',
]
_has_required_fields = True
def __init__(self,
name=None,
path_lower=None,
path_display=None,
parent_shared_folder_id=None):
self._name_value = None
self._name_present = False
self._path_lower_value = None
self._path_lower_present = False
self._path_display_value = None
self._path_display_present = False
self._parent_shared_folder_id_value = None
self._parent_shared_folder_id_present = False
if name is not None:
self.name = name
if path_lower is not None:
self.path_lower = path_lower
if path_display is not None:
self.path_display = path_display
if parent_shared_folder_id is not None:
self.parent_shared_folder_id = parent_shared_folder_id
@property
def name(self):
"""
The last component of the path (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 path_lower(self):
"""
The lowercased full path in the user's Dropbox. This always starts with
a slash. This field will be null if the file or folder is not mounted.
: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 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, and at least
the last path component will have the correct casing. Changes to only
the casing of paths won't be returned by
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue`. This field
will be null if the file or folder is not mounted.
: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 parent_shared_folder_id(self):
"""
Please use ``FileSharingInfo.parent_shared_folder_id`` or
``FolderSharingInfo.parent_shared_folder_id`` instead.
: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
def __repr__(self):
return 'Metadata(name={!r}, path_lower={!r}, path_display={!r}, parent_shared_folder_id={!r})'.format(
self._name_value,
self._path_lower_value,
self._path_display_value,
self._parent_shared_folder_id_value,
)
Metadata_validator = bv.StructTree(Metadata)
class DeletedMetadata(Metadata):
"""
Indicates that there used to be a file or folder at this path, but it no
longer exists.
"""
__slots__ = [
]
_has_required_fields = True
def __init__(self,
name=None,
path_lower=None,
path_display=None,
parent_shared_folder_id=None):
super(DeletedMetadata, self).__init__(name,
path_lower,
path_display,
parent_shared_folder_id)
def __repr__(self):
return 'DeletedMetadata(name={!r}, path_lower={!r}, path_display={!r}, parent_shared_folder_id={!r})'.format(
self._name_value,
self._path_lower_value,
self._path_display_value,
self._parent_shared_folder_id_value,
)
DeletedMetadata_validator = bv.Struct(DeletedMetadata)
class Dimensions(object):
"""
Dimensions for a photo or video.
:ivar height: Height of the photo/video.
:ivar width: Width of the photo/video.
"""
__slots__ = [
'_height_value',
'_height_present',
'_width_value',
'_width_present',
]
_has_required_fields = True
def __init__(self,
height=None,
width=None):
self._height_value = None
self._height_present = False
self._width_value = None
self._width_present = False
if height is not None:
self.height = height
if width is not None:
self.width = width
@property
def height(self):
"""
Height of the photo/video.
:rtype: long
"""
if self._height_present:
return self._height_value
else:
raise AttributeError("missing required field 'height'")
@height.setter
def height(self, val):
val = self._height_validator.validate(val)
self._height_value = val
self._height_present = True
@height.deleter
def height(self):
self._height_value = None
self._height_present = False
@property
def width(self):
"""
Width of the photo/video.
:rtype: long
"""
if self._width_present:
return self._width_value
else:
raise AttributeError("missing required field 'width'")
@width.setter
def width(self, val):
val = self._width_validator.validate(val)
self._width_value = val
self._width_present = True
@width.deleter
def width(self):
self._width_value = None
self._width_present = False
def __repr__(self):
return 'Dimensions(height={!r}, width={!r})'.format(
self._height_value,
self._width_value,
)
Dimensions_validator = bv.Struct(Dimensions)
class DownloadArg(object):
"""
:ivar path: The path of the file to download.
:ivar rev: Please specify revision in ``path`` instead.
"""
__slots__ = [
'_path_value',
'_path_present',
'_rev_value',
'_rev_present',
]
_has_required_fields = True
def __init__(self,
path=None,
rev=None):
self._path_value = None
self._path_present = False
self._rev_value = None
self._rev_present = False
if path is not None:
self.path = path
if rev is not None:
self.rev = rev
@property
def path(self):
"""
The path of the file to download.
: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 rev(self):
"""
Please specify revision in ``path`` instead.
:rtype: str
"""
if self._rev_present:
return self._rev_value
else:
return None
@rev.setter
def rev(self, val):
if val is None:
del self.rev
return
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
def __repr__(self):
return 'DownloadArg(path={!r}, rev={!r})'.format(
self._path_value,
self._rev_value,
)
DownloadArg_validator = bv.Struct(DownloadArg)
class DownloadError(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 LookupError val:
:rtype: DownloadError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'DownloadError(%r, %r)' % (self._tag, self._value)
DownloadError_validator = bv.Union(DownloadError)
class FileMetadata(Metadata):
"""
:ivar id: A unique identifier for the file.
:ivar client_modified: For files, this is the modification time set by the
desktop client when the file was added to Dropbox. Since this time is
not verified (the Dropbox server stores whatever the desktop client
sends up), this should only be used for display purposes (such as
sorting) and not, for example, to determine if a file has changed or
not.
:ivar server_modified: The last time the file was modified on Dropbox.
:ivar rev: A unique identifier for the current revision of a file. This
field is the same rev as elsewhere in the API and can be used to detect
changes and avoid conflicts.
:ivar size: The file size in bytes.
:ivar media_info: Additional information if the file is a photo or video.
:ivar sharing_info: Set if this file is contained in a shared folder.
:ivar property_groups: Additional information if the file has custom
properties with the property template specified.
:ivar has_explicit_shared_members: This flag will only be present if
include_has_explicit_shared_members is true in
:meth:`dropbox.dropbox.Dropbox.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_get_metadata`. If this flag is
present, it will be true if this file has any explicit shared members.
This is different from sharing_info in that this could be true in the
case where a file has explicit members but is not contained within a
shared folder.
:ivar content_hash: A hash of the file content. This field can be used to
verify data integrity. For more information see our `Content hash
</developers/reference/content-hash>`_ page.
"""
__slots__ = [
'_id_value',
'_id_present',
'_client_modified_value',
'_client_modified_present',
'_server_modified_value',
'_server_modified_present',
'_rev_value',
'_rev_present',
'_size_value',
'_size_present',
'_media_info_value',
'_media_info_present',
'_sharing_info_value',
'_sharing_info_present',
'_property_groups_value',
'_property_groups_present',
'_has_explicit_shared_members_value',
'_has_explicit_shared_members_present',
'_content_hash_value',
'_content_hash_present',
]
_has_required_fields = True
def __init__(self,
name=None,
id=None,
client_modified=None,
server_modified=None,
rev=None,
size=None,
path_lower=None,
path_display=None,
parent_shared_folder_id=None,
media_info=None,
sharing_info=None,
property_groups=None,
has_explicit_shared_members=None,
content_hash=None):
super(FileMetadata, self).__init__(name,
path_lower,
path_display,
parent_shared_folder_id)
self._id_value = None
self._id_present = False
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
self._media_info_value = None
self._media_info_present = False
self._sharing_info_value = None
self._sharing_info_present = False
self._property_groups_value = None
self._property_groups_present = False
self._has_explicit_shared_members_value = None
self._has_explicit_shared_members_present = False
self._content_hash_value = None
self._content_hash_present = False
if id is not None:
self.id = id
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
if media_info is not None:
self.media_info = media_info
if sharing_info is not None:
self.sharing_info = sharing_info
if property_groups is not None:
self.property_groups = property_groups
if has_explicit_shared_members is not None:
self.has_explicit_shared_members = has_explicit_shared_members
if content_hash is not None:
self.content_hash = content_hash
@property
def id(self):
"""
A unique identifier for 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 client_modified(self):
"""
For files, this is the modification time set by the desktop client when
the file was added to Dropbox. Since this time is not verified (the
Dropbox server stores whatever the desktop client sends up), this should
only be used for display purposes (such as sorting) and not, for
example, to determine if a file has changed or not.
:rtype: datetime.datetime
"""
if self._client_modified_present:
return self._client_modified_value
else:
raise AttributeError("missing required field 'client_modified'")
@client_modified.setter
def client_modified(self, val):
val = self._client_modified_validator.validate(val)
self._client_modified_value = val
self._client_modified_present = True
@client_modified.deleter
def client_modified(self):
self._client_modified_value = None
self._client_modified_present = False
@property
def server_modified(self):
"""
The last time the file was modified on Dropbox.
:rtype: datetime.datetime
"""
if self._server_modified_present:
return self._server_modified_value
else:
raise AttributeError("missing required field 'server_modified'")
@server_modified.setter
def server_modified(self, val):
val = self._server_modified_validator.validate(val)
self._server_modified_value = val
self._server_modified_present = True
@server_modified.deleter
def server_modified(self):
self._server_modified_value = None
self._server_modified_present = False
@property
def rev(self):
"""
A unique identifier for the current revision of a file. This field is
the same rev as elsewhere in the API and can be used to detect changes
and avoid conflicts.
:rtype: str
"""
if self._rev_present:
return self._rev_value
else:
raise AttributeError("missing required field 'rev'")
@rev.setter
def rev(self, val):
val = self._rev_validator.validate(val)
self._rev_value = val
self._rev_present = True
@rev.deleter
def rev(self):
self._rev_value = None
self._rev_present = False
@property
def size(self):
"""
The file size in bytes.
:rtype: long
"""
if self._size_present:
return self._size_value
else:
raise AttributeError("missing required field 'size'")
@size.setter
def size(self, val):
val = self._size_validator.validate(val)
self._size_value = val
self._size_present = True
@size.deleter
def size(self):
self._size_value = None
self._size_present = False
@property
def media_info(self):
"""
Additional information if the file is a photo or video.
:rtype: MediaInfo
"""
if self._media_info_present:
return self._media_info_value
else:
return None
@media_info.setter
def media_info(self, val):
if val is None:
del self.media_info
return
self._media_info_validator.validate_type_only(val)
self._media_info_value = val
self._media_info_present = True
@media_info.deleter
def media_info(self):
self._media_info_value = None
self._media_info_present = False
@property
def sharing_info(self):
"""
Set if this file is contained in a shared folder.
:rtype: FileSharingInfo
"""
if self._sharing_info_present:
return self._sharing_info_value
else:
return None
@sharing_info.setter
def sharing_info(self, val):
if val is None:
del self.sharing_info
return
self._sharing_info_validator.validate_type_only(val)
self._sharing_info_value = val
self._sharing_info_present = True
@sharing_info.deleter
def sharing_info(self):
self._sharing_info_value = None
self._sharing_info_present = False
@property
def property_groups(self):
"""
Additional information if the file has custom properties with the
property template specified.
:rtype: list of [file_properties.PropertyGroup_validator]
"""
if self._property_groups_present:
return self._property_groups_value
else:
return None
@property_groups.setter
def property_groups(self, val):
if val is None:
del self.property_groups
return
val = self._property_groups_validator.validate(val)
self._property_groups_value = val
self._property_groups_present = True
@property_groups.deleter
def property_groups(self):
self._property_groups_value = None
self._property_groups_present = False
@property
def has_explicit_shared_members(self):
"""
This flag will only be present if include_has_explicit_shared_members
is true in :meth:`dropbox.dropbox.Dropbox.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_get_metadata`. If this flag is
present, it will be true if this file has any explicit shared members.
This is different from sharing_info in that this could be true in the
case where a file has explicit members but is not contained within a
shared folder.
:rtype: bool
"""
if self._has_explicit_shared_members_present:
return self._has_explicit_shared_members_value
else:
return None
@has_explicit_shared_members.setter
def has_explicit_shared_members(self, val):
if val is None:
del self.has_explicit_shared_members
return
val = self._has_explicit_shared_members_validator.validate(val)
self._has_explicit_shared_members_value = val
self._has_explicit_shared_members_present = True
@has_explicit_shared_members.deleter
def has_explicit_shared_members(self):
self._has_explicit_shared_members_value = None
self._has_explicit_shared_members_present = False
@property
def content_hash(self):
"""
A hash of the file content. This field can be used to verify data
integrity. For more information see our `Content hash
</developers/reference/content-hash>`_ page.
:rtype: str
"""
if self._content_hash_present:
return self._content_hash_value
else:
return None
@content_hash.setter
def content_hash(self, val):
if val is None:
del self.content_hash
return
val = self._content_hash_validator.validate(val)
self._content_hash_value = val
self._content_hash_present = True
@content_hash.deleter
def content_hash(self):
self._content_hash_value = None
self._content_hash_present = False
def __repr__(self):
return 'FileMetadata(name={!r}, id={!r}, client_modified={!r}, server_modified={!r}, rev={!r}, size={!r}, path_lower={!r}, path_display={!r}, parent_shared_folder_id={!r}, media_info={!r}, sharing_info={!r}, property_groups={!r}, has_explicit_shared_members={!r}, content_hash={!r})'.format(
self._name_value,
self._id_value,
self._client_modified_value,
self._server_modified_value,
self._rev_value,
self._size_value,
self._path_lower_value,
self._path_display_value,
self._parent_shared_folder_id_value,
self._media_info_value,
self._sharing_info_value,
self._property_groups_value,
self._has_explicit_shared_members_value,
self._content_hash_value,
)
FileMetadata_validator = bv.Struct(FileMetadata)
class SharingInfo(object):
"""
Sharing info for a file or folder.
:ivar read_only: True if the file or folder is inside a read-only shared
folder.
"""
__slots__ = [
'_read_only_value',
'_read_only_present',
]
_has_required_fields = True
def __init__(self,
read_only=None):
self._read_only_value = None
self._read_only_present = False
if read_only is not None:
self.read_only = read_only
@property
def read_only(self):
"""
True if the file or folder is inside a read-only shared folder.
:rtype: bool
"""
if self._read_only_present:
return self._read_only_value
else:
raise AttributeError("missing required field 'read_only'")
@read_only.setter
def read_only(self, val):
val = self._read_only_validator.validate(val)
self._read_only_value = val
self._read_only_present = True
@read_only.deleter
def read_only(self):
self._read_only_value = None
self._read_only_present = False
def __repr__(self):
return 'SharingInfo(read_only={!r})'.format(
self._read_only_value,
)
SharingInfo_validator = bv.Struct(SharingInfo)
class FileSharingInfo(SharingInfo):
"""
Sharing info for a file which is contained by a shared folder.
:ivar parent_shared_folder_id: ID of shared folder that holds this file.
:ivar modified_by: The last user who modified the file. This field will be
null if the user's account has been deleted.
"""
__slots__ = [
'_parent_shared_folder_id_value',
'_parent_shared_folder_id_present',
'_modified_by_value',
'_modified_by_present',
]
_has_required_fields = True
def __init__(self,
read_only=None,
parent_shared_folder_id=None,
modified_by=None):
super(FileSharingInfo, self).__init__(read_only)
self._parent_shared_folder_id_value = None
self._parent_shared_folder_id_present = False
self._modified_by_value = None
self._modified_by_present = False
if parent_shared_folder_id is not None:
self.parent_shared_folder_id = parent_shared_folder_id
if modified_by is not None:
self.modified_by = modified_by
@property
def parent_shared_folder_id(self):
"""
ID of shared folder that holds this file.
:rtype: str
"""
if self._parent_shared_folder_id_present:
return self._parent_shared_folder_id_value
else:
raise AttributeError("missing required field 'parent_shared_folder_id'")
@parent_shared_folder_id.setter
def parent_shared_folder_id(self, val):
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 modified_by(self):
"""
The last user who modified the file. This field will be null if the
user's account has been deleted.
:rtype: str
"""
if self._modified_by_present:
return self._modified_by_value
else:
return None
@modified_by.setter
def modified_by(self, val):
if val is None:
del self.modified_by
return
val = self._modified_by_validator.validate(val)
self._modified_by_value = val
self._modified_by_present = True
@modified_by.deleter
def modified_by(self):
self._modified_by_value = None
self._modified_by_present = False
def __repr__(self):
return 'FileSharingInfo(read_only={!r}, parent_shared_folder_id={!r}, modified_by={!r})'.format(
self._read_only_value,
self._parent_shared_folder_id_value,
self._modified_by_value,
)
FileSharingInfo_validator = bv.Struct(FileSharingInfo)
class FolderMetadata(Metadata):
"""
:ivar id: A unique identifier for the folder.
:ivar shared_folder_id: Please use ``sharing_info`` instead.
:ivar sharing_info: Set if the folder is contained in a shared folder or is
a shared folder mount point.
:ivar property_groups: Additional information if the file has custom
properties with the property template specified.
"""
__slots__ = [
'_id_value',
'_id_present',
'_shared_folder_id_value',
'_shared_folder_id_present',
'_sharing_info_value',
'_sharing_info_present',
'_property_groups_value',
'_property_groups_present',
]
_has_required_fields = True
def __init__(self,
name=None,
id=None,
path_lower=None,
path_display=None,
parent_shared_folder_id=None,
shared_folder_id=None,
sharing_info=None,
property_groups=None):
super(FolderMetadata, self).__init__(name,
path_lower,
path_display,
parent_shared_folder_id)
self._id_value = None
self._id_present = False
self._shared_folder_id_value = None
self._shared_folder_id_present = False
self._sharing_info_value = None
self._sharing_info_present = False
self._property_groups_value = None
self._property_groups_present = False
if id is not None:
self.id = id
if shared_folder_id is not None:
self.shared_folder_id = shared_folder_id
if sharing_info is not None:
self.sharing_info = sharing_info
if property_groups is not None:
self.property_groups = property_groups
@property
def id(self):
"""
A unique identifier for the folder.
: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 shared_folder_id(self):
"""
Please use ``sharing_info`` instead.
:rtype: str
"""
if self._shared_folder_id_present:
return self._shared_folder_id_value
else:
return None
@shared_folder_id.setter
def shared_folder_id(self, val):
if val is None:
del self.shared_folder_id
return
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 sharing_info(self):
"""
Set if the folder is contained in a shared folder or is a shared folder
mount point.
:rtype: FolderSharingInfo
"""
if self._sharing_info_present:
return self._sharing_info_value
else:
return None
@sharing_info.setter
def sharing_info(self, val):
if val is None:
del self.sharing_info
return
self._sharing_info_validator.validate_type_only(val)
self._sharing_info_value = val
self._sharing_info_present = True
@sharing_info.deleter
def sharing_info(self):
self._sharing_info_value = None
self._sharing_info_present = False
@property
def property_groups(self):
"""
Additional information if the file has custom properties with the
property template specified.
:rtype: list of [file_properties.PropertyGroup_validator]
"""
if self._property_groups_present:
return self._property_groups_value
else:
return None
@property_groups.setter
def property_groups(self, val):
if val is None:
del self.property_groups
return
val = self._property_groups_validator.validate(val)
self._property_groups_value = val
self._property_groups_present = True
@property_groups.deleter
def property_groups(self):
self._property_groups_value = None
self._property_groups_present = False
def __repr__(self):
return 'FolderMetadata(name={!r}, id={!r}, path_lower={!r}, path_display={!r}, parent_shared_folder_id={!r}, shared_folder_id={!r}, sharing_info={!r}, property_groups={!r})'.format(
self._name_value,
self._id_value,
self._path_lower_value,
self._path_display_value,
self._parent_shared_folder_id_value,
self._shared_folder_id_value,
self._sharing_info_value,
self._property_groups_value,
)
FolderMetadata_validator = bv.Struct(FolderMetadata)
class FolderSharingInfo(SharingInfo):
"""
Sharing info for a folder which is contained in a shared folder or is a
shared folder mount point.
:ivar parent_shared_folder_id: Set if the folder is contained by a shared
folder.
:ivar shared_folder_id: If this folder is a shared folder mount point, the
ID of the shared folder mounted at this location.
:ivar traverse_only: Specifies that the folder can only be traversed and the
user can only see a limited subset of the contents of this folder
because they don't have read access to this folder. They do, however,
have access to some sub folder.
:ivar no_access: Specifies that the folder cannot be accessed by the user.
"""
__slots__ = [
'_parent_shared_folder_id_value',
'_parent_shared_folder_id_present',
'_shared_folder_id_value',
'_shared_folder_id_present',
'_traverse_only_value',
'_traverse_only_present',
'_no_access_value',
'_no_access_present',
]
_has_required_fields = True
def __init__(self,
read_only=None,
parent_shared_folder_id=None,
shared_folder_id=None,
traverse_only=None,
no_access=None):
super(FolderSharingInfo, self).__init__(read_only)
self._parent_shared_folder_id_value = None
self._parent_shared_folder_id_present = False
self._shared_folder_id_value = None
self._shared_folder_id_present = False
self._traverse_only_value = None
self._traverse_only_present = False
self._no_access_value = None
self._no_access_present = False
if parent_shared_folder_id is not None:
self.parent_shared_folder_id = parent_shared_folder_id
if shared_folder_id is not None:
self.shared_folder_id = shared_folder_id
if traverse_only is not None:
self.traverse_only = traverse_only
if no_access is not None:
self.no_access = no_access
@property
def parent_shared_folder_id(self):
"""
Set if the folder is contained by 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 shared_folder_id(self):
"""
If this folder is a shared folder mount point, the ID of the shared
folder mounted at this location.
:rtype: str
"""
if self._shared_folder_id_present:
return self._shared_folder_id_value
else:
return None
@shared_folder_id.setter
def shared_folder_id(self, val):
if val is None:
del self.shared_folder_id
return
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 traverse_only(self):
"""
Specifies that the folder can only be traversed and the user can only
see a limited subset of the contents of this folder because they don't
have read access to this folder. They do, however, have access to some
sub folder.
:rtype: bool
"""
if self._traverse_only_present:
return self._traverse_only_value
else:
return False
@traverse_only.setter
def traverse_only(self, val):
val = self._traverse_only_validator.validate(val)
self._traverse_only_value = val
self._traverse_only_present = True
@traverse_only.deleter
def traverse_only(self):
self._traverse_only_value = None
self._traverse_only_present = False
@property
def no_access(self):
"""
Specifies that the folder cannot be accessed by the user.
:rtype: bool
"""
if self._no_access_present:
return self._no_access_value
else:
return False
@no_access.setter
def no_access(self, val):
val = self._no_access_validator.validate(val)
self._no_access_value = val
self._no_access_present = True
@no_access.deleter
def no_access(self):
self._no_access_value = None
self._no_access_present = False
def __repr__(self):
return 'FolderSharingInfo(read_only={!r}, parent_shared_folder_id={!r}, shared_folder_id={!r}, traverse_only={!r}, no_access={!r})'.format(
self._read_only_value,
self._parent_shared_folder_id_value,
self._shared_folder_id_value,
self._traverse_only_value,
self._no_access_value,
)
FolderSharingInfo_validator = bv.Struct(FolderSharingInfo)
class GetCopyReferenceArg(object):
"""
:ivar path: The path to the file or folder you want to get a copy reference
to.
"""
__slots__ = [
'_path_value',
'_path_present',
]
_has_required_fields = True
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):
"""
The path to the file or folder you want to get a copy reference to.
:rtype: str
"""
if self._path_present:
return self._path_value
else:
raise AttributeError("missing required field 'path'")
@path.setter
def path(self, val):
val = self._path_validator.validate(val)
self._path_value = val
self._path_present = True
@path.deleter
def path(self):
self._path_value = None
self._path_present = False
def __repr__(self):
return 'GetCopyReferenceArg(path={!r})'.format(
self._path_value,
)
GetCopyReferenceArg_validator = bv.Struct(GetCopyReferenceArg)
class GetCopyReferenceError(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 LookupError val:
:rtype: GetCopyReferenceError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'GetCopyReferenceError(%r, %r)' % (self._tag, self._value)
GetCopyReferenceError_validator = bv.Union(GetCopyReferenceError)
class GetCopyReferenceResult(object):
"""
:ivar metadata: Metadata of the file or folder.
:ivar copy_reference: A copy reference to the file or folder.
:ivar expires: The expiration date of the copy reference. This value is
currently set to be far enough in the future so that expiration is
effectively not an issue.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
'_copy_reference_value',
'_copy_reference_present',
'_expires_value',
'_expires_present',
]
_has_required_fields = True
def __init__(self,
metadata=None,
copy_reference=None,
expires=None):
self._metadata_value = None
self._metadata_present = False
self._copy_reference_value = None
self._copy_reference_present = False
self._expires_value = None
self._expires_present = False
if metadata is not None:
self.metadata = metadata
if copy_reference is not None:
self.copy_reference = copy_reference
if expires is not None:
self.expires = expires
@property
def metadata(self):
"""
Metadata of the file or folder.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
@property
def copy_reference(self):
"""
A copy reference to the file or folder.
:rtype: str
"""
if self._copy_reference_present:
return self._copy_reference_value
else:
raise AttributeError("missing required field 'copy_reference'")
@copy_reference.setter
def copy_reference(self, val):
val = self._copy_reference_validator.validate(val)
self._copy_reference_value = val
self._copy_reference_present = True
@copy_reference.deleter
def copy_reference(self):
self._copy_reference_value = None
self._copy_reference_present = False
@property
def expires(self):
"""
The expiration date of the copy reference. This value is currently set
to be far enough in the future so that expiration is effectively not an
issue.
:rtype: datetime.datetime
"""
if self._expires_present:
return self._expires_value
else:
raise AttributeError("missing required field 'expires'")
@expires.setter
def expires(self, val):
val = self._expires_validator.validate(val)
self._expires_value = val
self._expires_present = True
@expires.deleter
def expires(self):
self._expires_value = None
self._expires_present = False
def __repr__(self):
return 'GetCopyReferenceResult(metadata={!r}, copy_reference={!r}, expires={!r})'.format(
self._metadata_value,
self._copy_reference_value,
self._expires_value,
)
GetCopyReferenceResult_validator = bv.Struct(GetCopyReferenceResult)
class GetTemporaryLinkArg(object):
"""
:ivar path: The path to the file you want a temporary link to.
"""
__slots__ = [
'_path_value',
'_path_present',
]
_has_required_fields = True
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):
"""
The path to the file you want a temporary link to.
:rtype: str
"""
if self._path_present:
return self._path_value
else:
raise AttributeError("missing required field 'path'")
@path.setter
def path(self, val):
val = self._path_validator.validate(val)
self._path_value = val
self._path_present = True
@path.deleter
def path(self):
self._path_value = None
self._path_present = False
def __repr__(self):
return 'GetTemporaryLinkArg(path={!r})'.format(
self._path_value,
)
GetTemporaryLinkArg_validator = bv.Struct(GetTemporaryLinkArg)
class GetTemporaryLinkError(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 LookupError val:
:rtype: GetTemporaryLinkError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'GetTemporaryLinkError(%r, %r)' % (self._tag, self._value)
GetTemporaryLinkError_validator = bv.Union(GetTemporaryLinkError)
class GetTemporaryLinkResult(object):
"""
:ivar metadata: Metadata of the file.
:ivar link: The temporary link which can be used to stream content the file.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
'_link_value',
'_link_present',
]
_has_required_fields = True
def __init__(self,
metadata=None,
link=None):
self._metadata_value = None
self._metadata_present = False
self._link_value = None
self._link_present = False
if metadata is not None:
self.metadata = metadata
if link is not None:
self.link = link
@property
def metadata(self):
"""
Metadata of the file.
:rtype: FileMetadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
@property
def link(self):
"""
The temporary link which can be used to stream content the file.
:rtype: str
"""
if self._link_present:
return self._link_value
else:
raise AttributeError("missing required field 'link'")
@link.setter
def link(self, val):
val = self._link_validator.validate(val)
self._link_value = val
self._link_present = True
@link.deleter
def link(self):
self._link_value = None
self._link_present = False
def __repr__(self):
return 'GetTemporaryLinkResult(metadata={!r}, link={!r})'.format(
self._metadata_value,
self._link_value,
)
GetTemporaryLinkResult_validator = bv.Struct(GetTemporaryLinkResult)
class GetThumbnailBatchArg(object):
"""
Arguments for :meth:`dropbox.dropbox.Dropbox.files_get_thumbnail_batch`.
:ivar entries: List of files to get thumbnails.
"""
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
List of files to get thumbnails.
:rtype: list of [ThumbnailArg]
"""
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
def __repr__(self):
return 'GetThumbnailBatchArg(entries={!r})'.format(
self._entries_value,
)
GetThumbnailBatchArg_validator = bv.Struct(GetThumbnailBatchArg)
class GetThumbnailBatchError(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 too_many_files: The operation involves more than 25 files.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
too_many_files = None
# Attribute is overwritten below the class definition
other = None
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 __repr__(self):
return 'GetThumbnailBatchError(%r, %r)' % (self._tag, self._value)
GetThumbnailBatchError_validator = bv.Union(GetThumbnailBatchError)
class GetThumbnailBatchResult(object):
"""
:ivar entries: List of files and their thumbnails.
"""
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
List of files and their thumbnails.
:rtype: list of [GetThumbnailBatchResultEntry]
"""
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
def __repr__(self):
return 'GetThumbnailBatchResult(entries={!r})'.format(
self._entries_value,
)
GetThumbnailBatchResult_validator = bv.Struct(GetThumbnailBatchResult)
class GetThumbnailBatchResultData(object):
__slots__ = [
'_metadata_value',
'_metadata_present',
'_thumbnail_value',
'_thumbnail_present',
]
_has_required_fields = True
def __init__(self,
metadata=None,
thumbnail=None):
self._metadata_value = None
self._metadata_present = False
self._thumbnail_value = None
self._thumbnail_present = False
if metadata is not None:
self.metadata = metadata
if thumbnail is not None:
self.thumbnail = thumbnail
@property
def metadata(self):
"""
:rtype: FileMetadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
@property
def thumbnail(self):
"""
:rtype: str
"""
if self._thumbnail_present:
return self._thumbnail_value
else:
raise AttributeError("missing required field 'thumbnail'")
@thumbnail.setter
def thumbnail(self, val):
val = self._thumbnail_validator.validate(val)
self._thumbnail_value = val
self._thumbnail_present = True
@thumbnail.deleter
def thumbnail(self):
self._thumbnail_value = None
self._thumbnail_present = False
def __repr__(self):
return 'GetThumbnailBatchResultData(metadata={!r}, thumbnail={!r})'.format(
self._metadata_value,
self._thumbnail_value,
)
GetThumbnailBatchResultData_validator = bv.Struct(GetThumbnailBatchResultData)
class GetThumbnailBatchResultEntry(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 ThumbnailError failure: The result for this file if it was an error.
"""
_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 GetThumbnailBatchResultData val:
:rtype: GetThumbnailBatchResultEntry
"""
return cls('success', val)
@classmethod
def failure(cls, val):
"""
Create an instance of this class set to the ``failure`` tag with value
``val``.
:param ThumbnailError val:
:rtype: GetThumbnailBatchResultEntry
"""
return cls('failure', val)
def is_success(self):
"""
Check if the union tag is ``success``.
:rtype: bool
"""
return self._tag == 'success'
def is_failure(self):
"""
Check if the union tag is ``failure``.
:rtype: bool
"""
return self._tag == 'failure'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_success(self):
"""
Only call this if :meth:`is_success` is true.
:rtype: GetThumbnailBatchResultData
"""
if not self.is_success():
raise AttributeError("tag 'success' not set")
return self._value
def get_failure(self):
"""
The result for this file if it was an error.
Only call this if :meth:`is_failure` is true.
:rtype: ThumbnailError
"""
if not self.is_failure():
raise AttributeError("tag 'failure' not set")
return self._value
def __repr__(self):
return 'GetThumbnailBatchResultEntry(%r, %r)' % (self._tag, self._value)
GetThumbnailBatchResultEntry_validator = bv.Union(GetThumbnailBatchResultEntry)
class GpsCoordinates(object):
"""
GPS coordinates for a photo or video.
:ivar latitude: Latitude of the GPS coordinates.
:ivar longitude: Longitude of the GPS coordinates.
"""
__slots__ = [
'_latitude_value',
'_latitude_present',
'_longitude_value',
'_longitude_present',
]
_has_required_fields = True
def __init__(self,
latitude=None,
longitude=None):
self._latitude_value = None
self._latitude_present = False
self._longitude_value = None
self._longitude_present = False
if latitude is not None:
self.latitude = latitude
if longitude is not None:
self.longitude = longitude
@property
def latitude(self):
"""
Latitude of the GPS coordinates.
:rtype: float
"""
if self._latitude_present:
return self._latitude_value
else:
raise AttributeError("missing required field 'latitude'")
@latitude.setter
def latitude(self, val):
val = self._latitude_validator.validate(val)
self._latitude_value = val
self._latitude_present = True
@latitude.deleter
def latitude(self):
self._latitude_value = None
self._latitude_present = False
@property
def longitude(self):
"""
Longitude of the GPS coordinates.
:rtype: float
"""
if self._longitude_present:
return self._longitude_value
else:
raise AttributeError("missing required field 'longitude'")
@longitude.setter
def longitude(self, val):
val = self._longitude_validator.validate(val)
self._longitude_value = val
self._longitude_present = True
@longitude.deleter
def longitude(self):
self._longitude_value = None
self._longitude_present = False
def __repr__(self):
return 'GpsCoordinates(latitude={!r}, longitude={!r})'.format(
self._latitude_value,
self._longitude_value,
)
GpsCoordinates_validator = bv.Struct(GpsCoordinates)
class ListFolderArg(object):
"""
:ivar path: A unique identifier for the file.
:ivar recursive: If true, the list folder operation will be applied
recursively to all subfolders and the response will contain contents of
all subfolders.
:ivar include_media_info: If true, ``FileMetadata.media_info`` is set for
photo and video.
:ivar include_deleted: If true, the results will include entries for files
and folders that used to exist but were deleted.
:ivar include_has_explicit_shared_members: If true, the results will include
a flag for each file indicating whether or not that file has any
explicit members.
:ivar include_mounted_folders: If true, the results will include entries
under mounted folders which includes app folder, shared folder and team
folder.
:ivar limit: The maximum number of results to return per request. Note: This
is an approximate number and there can be slightly more entries returned
in some cases.
:ivar shared_link: A shared link to list the contents of. If the link is
password-protected, the password must be provided. If this field is
present, ``ListFolderArg.path`` will be relative to root of the shared
link. Only non-recursive mode is supported for shared link.
"""
__slots__ = [
'_path_value',
'_path_present',
'_recursive_value',
'_recursive_present',
'_include_media_info_value',
'_include_media_info_present',
'_include_deleted_value',
'_include_deleted_present',
'_include_has_explicit_shared_members_value',
'_include_has_explicit_shared_members_present',
'_include_mounted_folders_value',
'_include_mounted_folders_present',
'_limit_value',
'_limit_present',
'_shared_link_value',
'_shared_link_present',
]
_has_required_fields = True
def __init__(self,
path=None,
recursive=None,
include_media_info=None,
include_deleted=None,
include_has_explicit_shared_members=None,
include_mounted_folders=None,
limit=None,
shared_link=None):
self._path_value = None
self._path_present = False
self._recursive_value = None
self._recursive_present = False
self._include_media_info_value = None
self._include_media_info_present = False
self._include_deleted_value = None
self._include_deleted_present = False
self._include_has_explicit_shared_members_value = None
self._include_has_explicit_shared_members_present = False
self._include_mounted_folders_value = None
self._include_mounted_folders_present = False
self._limit_value = None
self._limit_present = False
self._shared_link_value = None
self._shared_link_present = False
if path is not None:
self.path = path
if recursive is not None:
self.recursive = recursive
if include_media_info is not None:
self.include_media_info = include_media_info
if include_deleted is not None:
self.include_deleted = include_deleted
if include_has_explicit_shared_members is not None:
self.include_has_explicit_shared_members = include_has_explicit_shared_members
if include_mounted_folders is not None:
self.include_mounted_folders = include_mounted_folders
if limit is not None:
self.limit = limit
if shared_link is not None:
self.shared_link = shared_link
@property
def path(self):
"""
A unique identifier for the file.
: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 recursive(self):
"""
If true, the list folder operation will be applied recursively to all
subfolders and the response will contain contents of all subfolders.
:rtype: bool
"""
if self._recursive_present:
return self._recursive_value
else:
return False
@recursive.setter
def recursive(self, val):
val = self._recursive_validator.validate(val)
self._recursive_value = val
self._recursive_present = True
@recursive.deleter
def recursive(self):
self._recursive_value = None
self._recursive_present = False
@property
def include_media_info(self):
"""
If true, ``FileMetadata.media_info`` is set for photo and video.
:rtype: bool
"""
if self._include_media_info_present:
return self._include_media_info_value
else:
return False
@include_media_info.setter
def include_media_info(self, val):
val = self._include_media_info_validator.validate(val)
self._include_media_info_value = val
self._include_media_info_present = True
@include_media_info.deleter
def include_media_info(self):
self._include_media_info_value = None
self._include_media_info_present = False
@property
def include_deleted(self):
"""
If true, the results will include entries for files and folders that
used to exist but were deleted.
:rtype: bool
"""
if self._include_deleted_present:
return self._include_deleted_value
else:
return False
@include_deleted.setter
def include_deleted(self, val):
val = self._include_deleted_validator.validate(val)
self._include_deleted_value = val
self._include_deleted_present = True
@include_deleted.deleter
def include_deleted(self):
self._include_deleted_value = None
self._include_deleted_present = False
@property
def include_has_explicit_shared_members(self):
"""
If true, the results will include a flag for each file indicating
whether or not that file has any explicit members.
:rtype: bool
"""
if self._include_has_explicit_shared_members_present:
return self._include_has_explicit_shared_members_value
else:
return False
@include_has_explicit_shared_members.setter
def include_has_explicit_shared_members(self, val):
val = self._include_has_explicit_shared_members_validator.validate(val)
self._include_has_explicit_shared_members_value = val
self._include_has_explicit_shared_members_present = True
@include_has_explicit_shared_members.deleter
def include_has_explicit_shared_members(self):
self._include_has_explicit_shared_members_value = None
self._include_has_explicit_shared_members_present = False
@property
def include_mounted_folders(self):
"""
If true, the results will include entries under mounted folders which
includes app folder, shared folder and team folder.
:rtype: bool
"""
if self._include_mounted_folders_present:
return self._include_mounted_folders_value
else:
return True
@include_mounted_folders.setter
def include_mounted_folders(self, val):
val = self._include_mounted_folders_validator.validate(val)
self._include_mounted_folders_value = val
self._include_mounted_folders_present = True
@include_mounted_folders.deleter
def include_mounted_folders(self):
self._include_mounted_folders_value = None
self._include_mounted_folders_present = False
@property
def limit(self):
"""
The maximum number of results to return per request. Note: This is an
approximate number and there can be slightly more entries returned in
some cases.
:rtype: long
"""
if self._limit_present:
return self._limit_value
else:
return None
@limit.setter
def limit(self, val):
if val is None:
del self.limit
return
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 shared_link(self):
"""
A shared link to list the contents of. If the link is
password-protected, the password must be provided. If this field is
present, ``ListFolderArg.path`` will be relative to root of the shared
link. Only non-recursive mode is supported for shared link.
:rtype: SharedLink
"""
if self._shared_link_present:
return self._shared_link_value
else:
return None
@shared_link.setter
def shared_link(self, val):
if val is None:
del self.shared_link
return
self._shared_link_validator.validate_type_only(val)
self._shared_link_value = val
self._shared_link_present = True
@shared_link.deleter
def shared_link(self):
self._shared_link_value = None
self._shared_link_present = False
def __repr__(self):
return 'ListFolderArg(path={!r}, recursive={!r}, include_media_info={!r}, include_deleted={!r}, include_has_explicit_shared_members={!r}, include_mounted_folders={!r}, limit={!r}, shared_link={!r})'.format(
self._path_value,
self._recursive_value,
self._include_media_info_value,
self._include_deleted_value,
self._include_has_explicit_shared_members_value,
self._include_mounted_folders_value,
self._limit_value,
self._shared_link_value,
)
ListFolderArg_validator = bv.Struct(ListFolderArg)
class ListFolderContinueArg(object):
"""
:ivar cursor: The cursor returned by your last call to
:meth:`dropbox.dropbox.Dropbox.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_list_folder_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.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue`.
:rtype: str
"""
if self._cursor_present:
return self._cursor_value
else:
raise AttributeError("missing required field 'cursor'")
@cursor.setter
def cursor(self, val):
val = self._cursor_validator.validate(val)
self._cursor_value = val
self._cursor_present = True
@cursor.deleter
def cursor(self):
self._cursor_value = None
self._cursor_present = False
def __repr__(self):
return 'ListFolderContinueArg(cursor={!r})'.format(
self._cursor_value,
)
ListFolderContinueArg_validator = bv.Struct(ListFolderContinueArg)
class ListFolderContinueError(bb.Union):
"""
This class acts as a tagged union. Only one of the ``is_*`` methods will
return true. To get the associated value of a tag (if one exists), use the
corresponding ``get_*`` method.
:ivar reset: Indicates that the cursor has been invalidated. Call
:meth:`dropbox.dropbox.Dropbox.files_list_folder` 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 LookupError val:
:rtype: ListFolderContinueError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'ListFolderContinueError(%r, %r)' % (self._tag, self._value)
ListFolderContinueError_validator = bv.Union(ListFolderContinueError)
class ListFolderError(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 LookupError val:
:rtype: ListFolderError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'ListFolderError(%r, %r)' % (self._tag, self._value)
ListFolderError_validator = bv.Union(ListFolderError)
class ListFolderGetLatestCursorResult(object):
"""
:ivar cursor: Pass the cursor into
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to see what's
changed in the folder since your previous query.
"""
__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):
"""
Pass the cursor into
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to see what's
changed in the folder since your previous query.
:rtype: str
"""
if self._cursor_present:
return self._cursor_value
else:
raise AttributeError("missing required field 'cursor'")
@cursor.setter
def cursor(self, val):
val = self._cursor_validator.validate(val)
self._cursor_value = val
self._cursor_present = True
@cursor.deleter
def cursor(self):
self._cursor_value = None
self._cursor_present = False
def __repr__(self):
return 'ListFolderGetLatestCursorResult(cursor={!r})'.format(
self._cursor_value,
)
ListFolderGetLatestCursorResult_validator = bv.Struct(ListFolderGetLatestCursorResult)
class ListFolderLongpollArg(object):
"""
:ivar cursor: A cursor as returned by
:meth:`dropbox.dropbox.Dropbox.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue`. Cursors
retrieved by setting ``ListFolderArg.include_media_info`` to ``True``
are not supported.
:ivar timeout: A timeout in seconds. The request will block for at most this
length of time, plus up to 90 seconds of random jitter added to avoid
the thundering herd problem. Care should be taken when using this
parameter, as some network infrastructure does not support long
timeouts.
"""
__slots__ = [
'_cursor_value',
'_cursor_present',
'_timeout_value',
'_timeout_present',
]
_has_required_fields = True
def __init__(self,
cursor=None,
timeout=None):
self._cursor_value = None
self._cursor_present = False
self._timeout_value = None
self._timeout_present = False
if cursor is not None:
self.cursor = cursor
if timeout is not None:
self.timeout = timeout
@property
def cursor(self):
"""
A cursor as returned by
:meth:`dropbox.dropbox.Dropbox.files_list_folder` or
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue`. Cursors
retrieved by setting ``ListFolderArg.include_media_info`` to ``True``
are not supported.
: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
@property
def timeout(self):
"""
A timeout in seconds. The request will block for at most this length of
time, plus up to 90 seconds of random jitter added to avoid the
thundering herd problem. Care should be taken when using this parameter,
as some network infrastructure does not support long timeouts.
:rtype: long
"""
if self._timeout_present:
return self._timeout_value
else:
return 30
@timeout.setter
def timeout(self, val):
val = self._timeout_validator.validate(val)
self._timeout_value = val
self._timeout_present = True
@timeout.deleter
def timeout(self):
self._timeout_value = None
self._timeout_present = False
def __repr__(self):
return 'ListFolderLongpollArg(cursor={!r}, timeout={!r})'.format(
self._cursor_value,
self._timeout_value,
)
ListFolderLongpollArg_validator = bv.Struct(ListFolderLongpollArg)
class ListFolderLongpollError(bb.Union):
"""
This class acts as a tagged union. Only one of the ``is_*`` methods will
return true. To get the associated value of a tag (if one exists), use the
corresponding ``get_*`` method.
:ivar reset: Indicates that the cursor has been invalidated. Call
:meth:`dropbox.dropbox.Dropbox.files_list_folder` 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
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 __repr__(self):
return 'ListFolderLongpollError(%r, %r)' % (self._tag, self._value)
ListFolderLongpollError_validator = bv.Union(ListFolderLongpollError)
class ListFolderLongpollResult(object):
"""
:ivar changes: Indicates whether new changes are available. If true, call
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to retrieve
the changes.
:ivar backoff: If present, backoff for at least this many seconds before
calling :meth:`dropbox.dropbox.Dropbox.files_list_folder_longpoll`
again.
"""
__slots__ = [
'_changes_value',
'_changes_present',
'_backoff_value',
'_backoff_present',
]
_has_required_fields = True
def __init__(self,
changes=None,
backoff=None):
self._changes_value = None
self._changes_present = False
self._backoff_value = None
self._backoff_present = False
if changes is not None:
self.changes = changes
if backoff is not None:
self.backoff = backoff
@property
def changes(self):
"""
Indicates whether new changes are available. If true, call
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to retrieve
the changes.
:rtype: bool
"""
if self._changes_present:
return self._changes_value
else:
raise AttributeError("missing required field 'changes'")
@changes.setter
def changes(self, val):
val = self._changes_validator.validate(val)
self._changes_value = val
self._changes_present = True
@changes.deleter
def changes(self):
self._changes_value = None
self._changes_present = False
@property
def backoff(self):
"""
If present, backoff for at least this many seconds before calling
:meth:`dropbox.dropbox.Dropbox.files_list_folder_longpoll` again.
:rtype: long
"""
if self._backoff_present:
return self._backoff_value
else:
return None
@backoff.setter
def backoff(self, val):
if val is None:
del self.backoff
return
val = self._backoff_validator.validate(val)
self._backoff_value = val
self._backoff_present = True
@backoff.deleter
def backoff(self):
self._backoff_value = None
self._backoff_present = False
def __repr__(self):
return 'ListFolderLongpollResult(changes={!r}, backoff={!r})'.format(
self._changes_value,
self._backoff_value,
)
ListFolderLongpollResult_validator = bv.Struct(ListFolderLongpollResult)
class ListFolderResult(object):
"""
:ivar entries: The files and (direct) subfolders in the folder.
:ivar cursor: Pass the cursor into
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to see what's
changed in the folder since your previous query.
:ivar has_more: If true, then there are more entries available. Pass the
cursor to :meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to
retrieve the rest.
"""
__slots__ = [
'_entries_value',
'_entries_present',
'_cursor_value',
'_cursor_present',
'_has_more_value',
'_has_more_present',
]
_has_required_fields = True
def __init__(self,
entries=None,
cursor=None,
has_more=None):
self._entries_value = None
self._entries_present = False
self._cursor_value = None
self._cursor_present = False
self._has_more_value = None
self._has_more_present = False
if entries is not None:
self.entries = entries
if cursor is not None:
self.cursor = cursor
if has_more is not None:
self.has_more = has_more
@property
def entries(self):
"""
The files and (direct) subfolders in the folder.
:rtype: list of [Metadata]
"""
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):
"""
Pass the cursor into
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to see what's
changed in the folder since your previous query.
: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
@property
def has_more(self):
"""
If true, then there are more entries available. Pass the cursor to
:meth:`dropbox.dropbox.Dropbox.files_list_folder_continue` to retrieve
the rest.
: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
def __repr__(self):
return 'ListFolderResult(entries={!r}, cursor={!r}, has_more={!r})'.format(
self._entries_value,
self._cursor_value,
self._has_more_value,
)
ListFolderResult_validator = bv.Struct(ListFolderResult)
class ListRevisionsArg(object):
"""
:ivar path: The path to the file you want to see the revisions of.
:ivar mode: Determines the behavior of the API in listing the revisions for
a given file path or id.
:ivar limit: The maximum number of revision entries returned.
"""
__slots__ = [
'_path_value',
'_path_present',
'_mode_value',
'_mode_present',
'_limit_value',
'_limit_present',
]
_has_required_fields = True
def __init__(self,
path=None,
mode=None,
limit=None):
self._path_value = None
self._path_present = False
self._mode_value = None
self._mode_present = False
self._limit_value = None
self._limit_present = False
if path is not None:
self.path = path
if mode is not None:
self.mode = mode
if limit is not None:
self.limit = limit
@property
def path(self):
"""
The path to the file you want to see the revisions of.
: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 mode(self):
"""
Determines the behavior of the API in listing the revisions for a given
file path or id.
:rtype: ListRevisionsMode
"""
if self._mode_present:
return self._mode_value
else:
return ListRevisionsMode.path
@mode.setter
def mode(self, val):
self._mode_validator.validate_type_only(val)
self._mode_value = val
self._mode_present = True
@mode.deleter
def mode(self):
self._mode_value = None
self._mode_present = False
@property
def limit(self):
"""
The maximum number of revision entries returned.
:rtype: long
"""
if self._limit_present:
return self._limit_value
else:
return 10
@limit.setter
def limit(self, val):
val = self._limit_validator.validate(val)
self._limit_value = val
self._limit_present = True
@limit.deleter
def limit(self):
self._limit_value = None
self._limit_present = False
def __repr__(self):
return 'ListRevisionsArg(path={!r}, mode={!r}, limit={!r})'.format(
self._path_value,
self._mode_value,
self._limit_value,
)
ListRevisionsArg_validator = bv.Struct(ListRevisionsArg)
class ListRevisionsError(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 LookupError val:
:rtype: ListRevisionsError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'ListRevisionsError(%r, %r)' % (self._tag, self._value)
ListRevisionsError_validator = bv.Union(ListRevisionsError)
class ListRevisionsMode(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 path: Returns revisions with the same file path as identified by the
latest file entry at the given file path or id.
:ivar id: Returns revisions with the same file id as identified by the
latest file entry at the given file path or id.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
path = None
# Attribute is overwritten below the class definition
id = None
# Attribute is overwritten below the class definition
other = None
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_id(self):
"""
Check if the union tag is ``id``.
:rtype: bool
"""
return self._tag == 'id'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def __repr__(self):
return 'ListRevisionsMode(%r, %r)' % (self._tag, self._value)
ListRevisionsMode_validator = bv.Union(ListRevisionsMode)
class ListRevisionsResult(object):
"""
:ivar is_deleted: If the file identified by the latest revision in the
response is either deleted or moved.
:ivar server_deleted: The time of deletion if the file was deleted.
:ivar entries: The revisions for the file. Only revisions that are not
deleted will show up here.
"""
__slots__ = [
'_is_deleted_value',
'_is_deleted_present',
'_server_deleted_value',
'_server_deleted_present',
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
is_deleted=None,
entries=None,
server_deleted=None):
self._is_deleted_value = None
self._is_deleted_present = False
self._server_deleted_value = None
self._server_deleted_present = False
self._entries_value = None
self._entries_present = False
if is_deleted is not None:
self.is_deleted = is_deleted
if server_deleted is not None:
self.server_deleted = server_deleted
if entries is not None:
self.entries = entries
@property
def is_deleted(self):
"""
If the file identified by the latest revision in the response is either
deleted or moved.
:rtype: bool
"""
if self._is_deleted_present:
return self._is_deleted_value
else:
raise AttributeError("missing required field 'is_deleted'")
@is_deleted.setter
def is_deleted(self, val):
val = self._is_deleted_validator.validate(val)
self._is_deleted_value = val
self._is_deleted_present = True
@is_deleted.deleter
def is_deleted(self):
self._is_deleted_value = None
self._is_deleted_present = False
@property
def server_deleted(self):
"""
The time of deletion if the file was deleted.
:rtype: datetime.datetime
"""
if self._server_deleted_present:
return self._server_deleted_value
else:
return None
@server_deleted.setter
def server_deleted(self, val):
if val is None:
del self.server_deleted
return
val = self._server_deleted_validator.validate(val)
self._server_deleted_value = val
self._server_deleted_present = True
@server_deleted.deleter
def server_deleted(self):
self._server_deleted_value = None
self._server_deleted_present = False
@property
def entries(self):
"""
The revisions for the file. Only revisions that are not deleted will
show up here.
:rtype: list of [FileMetadata]
"""
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
def __repr__(self):
return 'ListRevisionsResult(is_deleted={!r}, entries={!r}, server_deleted={!r})'.format(
self._is_deleted_value,
self._entries_value,
self._server_deleted_value,
)
ListRevisionsResult_validator = bv.Struct(ListRevisionsResult)
class LookupError(bb.Union):
"""
This class acts as a tagged union. Only one of the ``is_*`` methods will
return true. To get the associated value of a tag (if one exists), use the
corresponding ``get_*`` method.
:ivar not_found: There is nothing at the given path.
:ivar not_file: We were expecting a file, but the given path refers to
something that isn't a file.
:ivar not_folder: We were expecting a folder, but the given path refers to
something that isn't a folder.
:ivar restricted_content: The file cannot be transferred because the content
is restricted. For example, sometimes there are legal restrictions due
to copyright claims.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
not_found = None
# Attribute is overwritten below the class definition
not_file = None
# Attribute is overwritten below the class definition
not_folder = None
# Attribute is overwritten below the class definition
restricted_content = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def malformed_path(cls, val):
"""
Create an instance of this class set to the ``malformed_path`` tag with
value ``val``.
:param Optional[str] val:
:rtype: LookupError
"""
return cls('malformed_path', val)
def is_malformed_path(self):
"""
Check if the union tag is ``malformed_path``.
:rtype: bool
"""
return self._tag == 'malformed_path'
def is_not_found(self):
"""
Check if the union tag is ``not_found``.
:rtype: bool
"""
return self._tag == 'not_found'
def is_not_file(self):
"""
Check if the union tag is ``not_file``.
:rtype: bool
"""
return self._tag == 'not_file'
def is_not_folder(self):
"""
Check if the union tag is ``not_folder``.
:rtype: bool
"""
return self._tag == 'not_folder'
def is_restricted_content(self):
"""
Check if the union tag is ``restricted_content``.
:rtype: bool
"""
return self._tag == 'restricted_content'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_malformed_path(self):
"""
Only call this if :meth:`is_malformed_path` is true.
:rtype: Optional[str]
"""
if not self.is_malformed_path():
raise AttributeError("tag 'malformed_path' not set")
return self._value
def __repr__(self):
return 'LookupError(%r, %r)' % (self._tag, self._value)
LookupError_validator = bv.Union(LookupError)
class MediaInfo(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 pending: Indicate the photo/video is still under processing and
metadata is not available yet.
:ivar MediaMetadata metadata: The metadata for the photo/video.
"""
_catch_all = None
# Attribute is overwritten below the class definition
pending = None
@classmethod
def metadata(cls, val):
"""
Create an instance of this class set to the ``metadata`` tag with value
``val``.
:param MediaMetadata val:
:rtype: MediaInfo
"""
return cls('metadata', val)
def is_pending(self):
"""
Check if the union tag is ``pending``.
:rtype: bool
"""
return self._tag == 'pending'
def is_metadata(self):
"""
Check if the union tag is ``metadata``.
:rtype: bool
"""
return self._tag == 'metadata'
def get_metadata(self):
"""
The metadata for the photo/video.
Only call this if :meth:`is_metadata` is true.
:rtype: MediaMetadata
"""
if not self.is_metadata():
raise AttributeError("tag 'metadata' not set")
return self._value
def __repr__(self):
return 'MediaInfo(%r, %r)' % (self._tag, self._value)
MediaInfo_validator = bv.Union(MediaInfo)
class MediaMetadata(object):
"""
Metadata for a photo or video.
:ivar dimensions: Dimension of the photo/video.
:ivar location: The GPS coordinate of the photo/video.
:ivar time_taken: The timestamp when the photo/video is taken.
"""
__slots__ = [
'_dimensions_value',
'_dimensions_present',
'_location_value',
'_location_present',
'_time_taken_value',
'_time_taken_present',
]
_has_required_fields = False
def __init__(self,
dimensions=None,
location=None,
time_taken=None):
self._dimensions_value = None
self._dimensions_present = False
self._location_value = None
self._location_present = False
self._time_taken_value = None
self._time_taken_present = False
if dimensions is not None:
self.dimensions = dimensions
if location is not None:
self.location = location
if time_taken is not None:
self.time_taken = time_taken
@property
def dimensions(self):
"""
Dimension of the photo/video.
:rtype: Dimensions
"""
if self._dimensions_present:
return self._dimensions_value
else:
return None
@dimensions.setter
def dimensions(self, val):
if val is None:
del self.dimensions
return
self._dimensions_validator.validate_type_only(val)
self._dimensions_value = val
self._dimensions_present = True
@dimensions.deleter
def dimensions(self):
self._dimensions_value = None
self._dimensions_present = False
@property
def location(self):
"""
The GPS coordinate of the photo/video.
:rtype: GpsCoordinates
"""
if self._location_present:
return self._location_value
else:
return None
@location.setter
def location(self, val):
if val is None:
del self.location
return
self._location_validator.validate_type_only(val)
self._location_value = val
self._location_present = True
@location.deleter
def location(self):
self._location_value = None
self._location_present = False
@property
def time_taken(self):
"""
The timestamp when the photo/video is taken.
:rtype: datetime.datetime
"""
if self._time_taken_present:
return self._time_taken_value
else:
return None
@time_taken.setter
def time_taken(self, val):
if val is None:
del self.time_taken
return
val = self._time_taken_validator.validate(val)
self._time_taken_value = val
self._time_taken_present = True
@time_taken.deleter
def time_taken(self):
self._time_taken_value = None
self._time_taken_present = False
def __repr__(self):
return 'MediaMetadata(dimensions={!r}, location={!r}, time_taken={!r})'.format(
self._dimensions_value,
self._location_value,
self._time_taken_value,
)
MediaMetadata_validator = bv.StructTree(MediaMetadata)
class PhotoMetadata(MediaMetadata):
"""
Metadata for a photo.
"""
__slots__ = [
]
_has_required_fields = False
def __init__(self,
dimensions=None,
location=None,
time_taken=None):
super(PhotoMetadata, self).__init__(dimensions,
location,
time_taken)
def __repr__(self):
return 'PhotoMetadata(dimensions={!r}, location={!r}, time_taken={!r})'.format(
self._dimensions_value,
self._location_value,
self._time_taken_value,
)
PhotoMetadata_validator = bv.Struct(PhotoMetadata)
class PreviewArg(object):
"""
:ivar path: The path of the file to preview.
:ivar rev: Please specify revision in ``path`` instead.
"""
__slots__ = [
'_path_value',
'_path_present',
'_rev_value',
'_rev_present',
]
_has_required_fields = True
def __init__(self,
path=None,
rev=None):
self._path_value = None
self._path_present = False
self._rev_value = None
self._rev_present = False
if path is not None:
self.path = path
if rev is not None:
self.rev = rev
@property
def path(self):
"""
The path of the file to preview.
: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 rev(self):
"""
Please specify revision in ``path`` instead.
:rtype: str
"""
if self._rev_present:
return self._rev_value
else:
return None
@rev.setter
def rev(self, val):
if val is None:
del self.rev
return
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
def __repr__(self):
return 'PreviewArg(path={!r}, rev={!r})'.format(
self._path_value,
self._rev_value,
)
PreviewArg_validator = bv.Struct(PreviewArg)
class PreviewError(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 LookupError path: An error occurs when downloading metadata for the
file.
:ivar in_progress: This preview generation is still in progress and the file
is not ready for preview yet.
:ivar unsupported_extension: The file extension is not supported preview
generation.
:ivar unsupported_content: The file content is not supported for preview
generation.
"""
_catch_all = None
# Attribute is overwritten below the class definition
in_progress = None
# Attribute is overwritten below the class definition
unsupported_extension = None
# Attribute is overwritten below the class definition
unsupported_content = None
@classmethod
def path(cls, val):
"""
Create an instance of this class set to the ``path`` tag with value
``val``.
:param LookupError val:
:rtype: PreviewError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_in_progress(self):
"""
Check if the union tag is ``in_progress``.
:rtype: bool
"""
return self._tag == 'in_progress'
def is_unsupported_extension(self):
"""
Check if the union tag is ``unsupported_extension``.
:rtype: bool
"""
return self._tag == 'unsupported_extension'
def is_unsupported_content(self):
"""
Check if the union tag is ``unsupported_content``.
:rtype: bool
"""
return self._tag == 'unsupported_content'
def get_path(self):
"""
An error occurs when downloading metadata for the file.
Only call this if :meth:`is_path` is true.
:rtype: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'PreviewError(%r, %r)' % (self._tag, self._value)
PreviewError_validator = bv.Union(PreviewError)
class RelocationPath(object):
"""
:ivar from_path: Path in the user's Dropbox to be copied or moved.
:ivar to_path: Path in the user's Dropbox that is the destination.
"""
__slots__ = [
'_from_path_value',
'_from_path_present',
'_to_path_value',
'_to_path_present',
]
_has_required_fields = True
def __init__(self,
from_path=None,
to_path=None):
self._from_path_value = None
self._from_path_present = False
self._to_path_value = None
self._to_path_present = False
if from_path is not None:
self.from_path = from_path
if to_path is not None:
self.to_path = to_path
@property
def from_path(self):
"""
Path in the user's Dropbox to be copied or moved.
:rtype: str
"""
if self._from_path_present:
return self._from_path_value
else:
raise AttributeError("missing required field 'from_path'")
@from_path.setter
def from_path(self, val):
val = self._from_path_validator.validate(val)
self._from_path_value = val
self._from_path_present = True
@from_path.deleter
def from_path(self):
self._from_path_value = None
self._from_path_present = False
@property
def to_path(self):
"""
Path in the user's Dropbox that is the destination.
:rtype: str
"""
if self._to_path_present:
return self._to_path_value
else:
raise AttributeError("missing required field 'to_path'")
@to_path.setter
def to_path(self, val):
val = self._to_path_validator.validate(val)
self._to_path_value = val
self._to_path_present = True
@to_path.deleter
def to_path(self):
self._to_path_value = None
self._to_path_present = False
def __repr__(self):
return 'RelocationPath(from_path={!r}, to_path={!r})'.format(
self._from_path_value,
self._to_path_value,
)
RelocationPath_validator = bv.Struct(RelocationPath)
class RelocationArg(RelocationPath):
"""
:ivar allow_shared_folder: If true,
:meth:`dropbox.dropbox.Dropbox.files_copy` will copy contents in shared
folder, otherwise ``RelocationError.cant_copy_shared_folder`` will be
returned if ``from_path`` contains shared folder. This field is always
true for :meth:`dropbox.dropbox.Dropbox.files_move`.
:ivar autorename: If there's a conflict, have the Dropbox server try to
autorename the file to avoid the conflict.
:ivar allow_ownership_transfer: Allow moves by owner even if it would result
in an ownership transfer for the content being moved. This does not
apply to copies.
"""
__slots__ = [
'_allow_shared_folder_value',
'_allow_shared_folder_present',
'_autorename_value',
'_autorename_present',
'_allow_ownership_transfer_value',
'_allow_ownership_transfer_present',
]
_has_required_fields = True
def __init__(self,
from_path=None,
to_path=None,
allow_shared_folder=None,
autorename=None,
allow_ownership_transfer=None):
super(RelocationArg, self).__init__(from_path,
to_path)
self._allow_shared_folder_value = None
self._allow_shared_folder_present = False
self._autorename_value = None
self._autorename_present = False
self._allow_ownership_transfer_value = None
self._allow_ownership_transfer_present = False
if allow_shared_folder is not None:
self.allow_shared_folder = allow_shared_folder
if autorename is not None:
self.autorename = autorename
if allow_ownership_transfer is not None:
self.allow_ownership_transfer = allow_ownership_transfer
@property
def allow_shared_folder(self):
"""
If true, :meth:`dropbox.dropbox.Dropbox.files_copy` will copy contents
in shared folder, otherwise ``RelocationError.cant_copy_shared_folder``
will be returned if ``from_path`` contains shared folder. This field is
always true for :meth:`dropbox.dropbox.Dropbox.files_move`.
:rtype: bool
"""
if self._allow_shared_folder_present:
return self._allow_shared_folder_value
else:
return False
@allow_shared_folder.setter
def allow_shared_folder(self, val):
val = self._allow_shared_folder_validator.validate(val)
self._allow_shared_folder_value = val
self._allow_shared_folder_present = True
@allow_shared_folder.deleter
def allow_shared_folder(self):
self._allow_shared_folder_value = None
self._allow_shared_folder_present = False
@property
def autorename(self):
"""
If there's a conflict, have the Dropbox server try to autorename the
file to avoid the conflict.
:rtype: bool
"""
if self._autorename_present:
return self._autorename_value
else:
return False
@autorename.setter
def autorename(self, val):
val = self._autorename_validator.validate(val)
self._autorename_value = val
self._autorename_present = True
@autorename.deleter
def autorename(self):
self._autorename_value = None
self._autorename_present = False
@property
def allow_ownership_transfer(self):
"""
Allow moves by owner even if it would result in an ownership transfer
for the content being moved. This does not apply to copies.
:rtype: bool
"""
if self._allow_ownership_transfer_present:
return self._allow_ownership_transfer_value
else:
return False
@allow_ownership_transfer.setter
def allow_ownership_transfer(self, val):
val = self._allow_ownership_transfer_validator.validate(val)
self._allow_ownership_transfer_value = val
self._allow_ownership_transfer_present = True
@allow_ownership_transfer.deleter
def allow_ownership_transfer(self):
self._allow_ownership_transfer_value = None
self._allow_ownership_transfer_present = False
def __repr__(self):
return 'RelocationArg(from_path={!r}, to_path={!r}, allow_shared_folder={!r}, autorename={!r}, allow_ownership_transfer={!r})'.format(
self._from_path_value,
self._to_path_value,
self._allow_shared_folder_value,
self._autorename_value,
self._allow_ownership_transfer_value,
)
RelocationArg_validator = bv.Struct(RelocationArg)
class RelocationBatchArg(object):
"""
:ivar entries: List of entries to be moved or copied. Each entry is
:class:`RelocationPath`.
:ivar allow_shared_folder: If true,
:meth:`dropbox.dropbox.Dropbox.files_copy_batch` will copy contents in
shared folder, otherwise ``RelocationError.cant_copy_shared_folder``
will be returned if ``RelocationPath.from_path`` contains shared folder.
This field is always true for
:meth:`dropbox.dropbox.Dropbox.files_move_batch`.
:ivar autorename: If there's a conflict with any file, have the Dropbox
server try to autorename that file to avoid the conflict.
:ivar allow_ownership_transfer: Allow moves by owner even if it would result
in an ownership transfer for the content being moved. This does not
apply to copies.
"""
__slots__ = [
'_entries_value',
'_entries_present',
'_allow_shared_folder_value',
'_allow_shared_folder_present',
'_autorename_value',
'_autorename_present',
'_allow_ownership_transfer_value',
'_allow_ownership_transfer_present',
]
_has_required_fields = True
def __init__(self,
entries=None,
allow_shared_folder=None,
autorename=None,
allow_ownership_transfer=None):
self._entries_value = None
self._entries_present = False
self._allow_shared_folder_value = None
self._allow_shared_folder_present = False
self._autorename_value = None
self._autorename_present = False
self._allow_ownership_transfer_value = None
self._allow_ownership_transfer_present = False
if entries is not None:
self.entries = entries
if allow_shared_folder is not None:
self.allow_shared_folder = allow_shared_folder
if autorename is not None:
self.autorename = autorename
if allow_ownership_transfer is not None:
self.allow_ownership_transfer = allow_ownership_transfer
@property
def entries(self):
"""
List of entries to be moved or copied. Each entry is
:class:`RelocationPath`.
:rtype: list of [RelocationPath]
"""
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 allow_shared_folder(self):
"""
If true, :meth:`dropbox.dropbox.Dropbox.files_copy_batch` will copy
contents in shared folder, otherwise
``RelocationError.cant_copy_shared_folder`` will be returned if
``RelocationPath.from_path`` contains shared folder. This field is
always true for :meth:`dropbox.dropbox.Dropbox.files_move_batch`.
:rtype: bool
"""
if self._allow_shared_folder_present:
return self._allow_shared_folder_value
else:
return False
@allow_shared_folder.setter
def allow_shared_folder(self, val):
val = self._allow_shared_folder_validator.validate(val)
self._allow_shared_folder_value = val
self._allow_shared_folder_present = True
@allow_shared_folder.deleter
def allow_shared_folder(self):
self._allow_shared_folder_value = None
self._allow_shared_folder_present = False
@property
def autorename(self):
"""
If there's a conflict with any file, have the Dropbox server try to
autorename that file to avoid the conflict.
:rtype: bool
"""
if self._autorename_present:
return self._autorename_value
else:
return False
@autorename.setter
def autorename(self, val):
val = self._autorename_validator.validate(val)
self._autorename_value = val
self._autorename_present = True
@autorename.deleter
def autorename(self):
self._autorename_value = None
self._autorename_present = False
@property
def allow_ownership_transfer(self):
"""
Allow moves by owner even if it would result in an ownership transfer
for the content being moved. This does not apply to copies.
:rtype: bool
"""
if self._allow_ownership_transfer_present:
return self._allow_ownership_transfer_value
else:
return False
@allow_ownership_transfer.setter
def allow_ownership_transfer(self, val):
val = self._allow_ownership_transfer_validator.validate(val)
self._allow_ownership_transfer_value = val
self._allow_ownership_transfer_present = True
@allow_ownership_transfer.deleter
def allow_ownership_transfer(self):
self._allow_ownership_transfer_value = None
self._allow_ownership_transfer_present = False
def __repr__(self):
return 'RelocationBatchArg(entries={!r}, allow_shared_folder={!r}, autorename={!r}, allow_ownership_transfer={!r})'.format(
self._entries_value,
self._allow_shared_folder_value,
self._autorename_value,
self._allow_ownership_transfer_value,
)
RelocationBatchArg_validator = bv.Struct(RelocationBatchArg)
class RelocationError(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 cant_copy_shared_folder: Shared folders can't be copied.
:ivar cant_nest_shared_folder: Your move operation would result in nested
shared folders. This is not allowed.
:ivar cant_move_folder_into_itself: You cannot move a folder into itself.
:ivar too_many_files: The operation would involve more than 10,000 files and
folders.
:ivar duplicated_or_nested_paths: There are duplicated/nested paths among
``RelocationArg.from_path`` and ``RelocationArg.to_path``.
:ivar cant_transfer_ownership: Your move operation would result in an
ownership transfer. You may reissue the request with the field
``RelocationArg.allow_ownership_transfer`` to true.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
cant_copy_shared_folder = None
# Attribute is overwritten below the class definition
cant_nest_shared_folder = None
# Attribute is overwritten below the class definition
cant_move_folder_into_itself = None
# Attribute is overwritten below the class definition
too_many_files = None
# Attribute is overwritten below the class definition
duplicated_or_nested_paths = None
# Attribute is overwritten below the class definition
cant_transfer_ownership = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def from_lookup(cls, val):
"""
Create an instance of this class set to the ``from_lookup`` tag with
value ``val``.
:param LookupError val:
:rtype: RelocationError
"""
return cls('from_lookup', val)
@classmethod
def from_write(cls, val):
"""
Create an instance of this class set to the ``from_write`` tag with
value ``val``.
:param WriteError val:
:rtype: RelocationError
"""
return cls('from_write', val)
@classmethod
def to(cls, val):
"""
Create an instance of this class set to the ``to`` tag with value
``val``.
:param WriteError val:
:rtype: RelocationError
"""
return cls('to', val)
def is_from_lookup(self):
"""
Check if the union tag is ``from_lookup``.
:rtype: bool
"""
return self._tag == 'from_lookup'
def is_from_write(self):
"""
Check if the union tag is ``from_write``.
:rtype: bool
"""
return self._tag == 'from_write'
def is_to(self):
"""
Check if the union tag is ``to``.
:rtype: bool
"""
return self._tag == 'to'
def is_cant_copy_shared_folder(self):
"""
Check if the union tag is ``cant_copy_shared_folder``.
:rtype: bool
"""
return self._tag == 'cant_copy_shared_folder'
def is_cant_nest_shared_folder(self):
"""
Check if the union tag is ``cant_nest_shared_folder``.
:rtype: bool
"""
return self._tag == 'cant_nest_shared_folder'
def is_cant_move_folder_into_itself(self):
"""
Check if the union tag is ``cant_move_folder_into_itself``.
:rtype: bool
"""
return self._tag == 'cant_move_folder_into_itself'
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_duplicated_or_nested_paths(self):
"""
Check if the union tag is ``duplicated_or_nested_paths``.
:rtype: bool
"""
return self._tag == 'duplicated_or_nested_paths'
def is_cant_transfer_ownership(self):
"""
Check if the union tag is ``cant_transfer_ownership``.
:rtype: bool
"""
return self._tag == 'cant_transfer_ownership'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_from_lookup(self):
"""
Only call this if :meth:`is_from_lookup` is true.
:rtype: LookupError
"""
if not self.is_from_lookup():
raise AttributeError("tag 'from_lookup' not set")
return self._value
def get_from_write(self):
"""
Only call this if :meth:`is_from_write` is true.
:rtype: WriteError
"""
if not self.is_from_write():
raise AttributeError("tag 'from_write' not set")
return self._value
def get_to(self):
"""
Only call this if :meth:`is_to` is true.
:rtype: WriteError
"""
if not self.is_to():
raise AttributeError("tag 'to' not set")
return self._value
def __repr__(self):
return 'RelocationError(%r, %r)' % (self._tag, self._value)
RelocationError_validator = bv.Union(RelocationError)
class RelocationBatchError(RelocationError):
"""
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 too_many_write_operations: There are too many write operations in
user's Dropbox. Please retry this request.
"""
# Attribute is overwritten below the class definition
too_many_write_operations = None
def is_too_many_write_operations(self):
"""
Check if the union tag is ``too_many_write_operations``.
:rtype: bool
"""
return self._tag == 'too_many_write_operations'
def __repr__(self):
return 'RelocationBatchError(%r, %r)' % (self._tag, self._value)
RelocationBatchError_validator = bv.Union(RelocationBatchError)
class RelocationBatchJobStatus(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 RelocationBatchResult complete: The copy or move batch job has
finished.
:ivar RelocationBatchError failed: The copy or move batch job has failed
with exception.
"""
@classmethod
def complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param RelocationBatchResult val:
:rtype: RelocationBatchJobStatus
"""
return cls('complete', val)
@classmethod
def failed(cls, val):
"""
Create an instance of this class set to the ``failed`` tag with value
``val``.
:param RelocationBatchError val:
:rtype: RelocationBatchJobStatus
"""
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 copy or move batch job has finished.
Only call this if :meth:`is_complete` is true.
:rtype: RelocationBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def get_failed(self):
"""
The copy or move batch job has failed with exception.
Only call this if :meth:`is_failed` is true.
:rtype: RelocationBatchError
"""
if not self.is_failed():
raise AttributeError("tag 'failed' not set")
return self._value
def __repr__(self):
return 'RelocationBatchJobStatus(%r, %r)' % (self._tag, self._value)
RelocationBatchJobStatus_validator = bv.Union(RelocationBatchJobStatus)
class RelocationBatchLaunch(async.LaunchResultBase):
"""
Result returned by :meth:`dropbox.dropbox.Dropbox.files_copy_batch` or
:meth:`dropbox.dropbox.Dropbox.files_move_batch` that may either launch an
asynchronous job or complete synchronously.
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 complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param RelocationBatchResult val:
:rtype: RelocationBatchLaunch
"""
return cls('complete', val)
def is_complete(self):
"""
Check if the union tag is ``complete``.
:rtype: bool
"""
return self._tag == 'complete'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_complete(self):
"""
Only call this if :meth:`is_complete` is true.
:rtype: RelocationBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def __repr__(self):
return 'RelocationBatchLaunch(%r, %r)' % (self._tag, self._value)
RelocationBatchLaunch_validator = bv.Union(RelocationBatchLaunch)
class RelocationBatchResult(FileOpsResult):
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
super(RelocationBatchResult, self).__init__()
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
:rtype: list of [RelocationBatchResultData]
"""
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
def __repr__(self):
return 'RelocationBatchResult(entries={!r})'.format(
self._entries_value,
)
RelocationBatchResult_validator = bv.Struct(RelocationBatchResult)
class RelocationBatchResultData(object):
"""
:ivar metadata: Metadata of the relocated object.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
Metadata of the relocated object.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'RelocationBatchResultData(metadata={!r})'.format(
self._metadata_value,
)
RelocationBatchResultData_validator = bv.Struct(RelocationBatchResultData)
class RelocationResult(FileOpsResult):
"""
:ivar metadata: Metadata of the relocated object.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
super(RelocationResult, self).__init__()
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
Metadata of the relocated object.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'RelocationResult(metadata={!r})'.format(
self._metadata_value,
)
RelocationResult_validator = bv.Struct(RelocationResult)
class RestoreArg(object):
"""
:ivar path: The path to the file you want to restore.
:ivar rev: The revision to restore for the file.
"""
__slots__ = [
'_path_value',
'_path_present',
'_rev_value',
'_rev_present',
]
_has_required_fields = True
def __init__(self,
path=None,
rev=None):
self._path_value = None
self._path_present = False
self._rev_value = None
self._rev_present = False
if path is not None:
self.path = path
if rev is not None:
self.rev = rev
@property
def path(self):
"""
The path to the file you want to restore.
: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 rev(self):
"""
The revision to restore for the file.
: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
def __repr__(self):
return 'RestoreArg(path={!r}, rev={!r})'.format(
self._path_value,
self._rev_value,
)
RestoreArg_validator = bv.Struct(RestoreArg)
class RestoreError(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 LookupError path_lookup: An error occurs when downloading metadata for
the file.
:ivar WriteError path_write: An error occurs when trying to restore the file
to that path.
:ivar invalid_revision: The revision is invalid. It may point to a different
file.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
invalid_revision = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def path_lookup(cls, val):
"""
Create an instance of this class set to the ``path_lookup`` tag with
value ``val``.
:param LookupError val:
:rtype: RestoreError
"""
return cls('path_lookup', val)
@classmethod
def path_write(cls, val):
"""
Create an instance of this class set to the ``path_write`` tag with
value ``val``.
:param WriteError val:
:rtype: RestoreError
"""
return cls('path_write', val)
def is_path_lookup(self):
"""
Check if the union tag is ``path_lookup``.
:rtype: bool
"""
return self._tag == 'path_lookup'
def is_path_write(self):
"""
Check if the union tag is ``path_write``.
:rtype: bool
"""
return self._tag == 'path_write'
def is_invalid_revision(self):
"""
Check if the union tag is ``invalid_revision``.
:rtype: bool
"""
return self._tag == 'invalid_revision'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_path_lookup(self):
"""
An error occurs when downloading metadata for the file.
Only call this if :meth:`is_path_lookup` is true.
:rtype: LookupError
"""
if not self.is_path_lookup():
raise AttributeError("tag 'path_lookup' not set")
return self._value
def get_path_write(self):
"""
An error occurs when trying to restore the file to that path.
Only call this if :meth:`is_path_write` is true.
:rtype: WriteError
"""
if not self.is_path_write():
raise AttributeError("tag 'path_write' not set")
return self._value
def __repr__(self):
return 'RestoreError(%r, %r)' % (self._tag, self._value)
RestoreError_validator = bv.Union(RestoreError)
class SaveCopyReferenceArg(object):
"""
:ivar copy_reference: A copy reference returned by
:meth:`dropbox.dropbox.Dropbox.files_copy_reference_get`.
:ivar path: Path in the user's Dropbox that is the destination.
"""
__slots__ = [
'_copy_reference_value',
'_copy_reference_present',
'_path_value',
'_path_present',
]
_has_required_fields = True
def __init__(self,
copy_reference=None,
path=None):
self._copy_reference_value = None
self._copy_reference_present = False
self._path_value = None
self._path_present = False
if copy_reference is not None:
self.copy_reference = copy_reference
if path is not None:
self.path = path
@property
def copy_reference(self):
"""
A copy reference returned by
:meth:`dropbox.dropbox.Dropbox.files_copy_reference_get`.
:rtype: str
"""
if self._copy_reference_present:
return self._copy_reference_value
else:
raise AttributeError("missing required field 'copy_reference'")
@copy_reference.setter
def copy_reference(self, val):
val = self._copy_reference_validator.validate(val)
self._copy_reference_value = val
self._copy_reference_present = True
@copy_reference.deleter
def copy_reference(self):
self._copy_reference_value = None
self._copy_reference_present = False
@property
def path(self):
"""
Path in the user's Dropbox that is the destination.
:rtype: str
"""
if self._path_present:
return self._path_value
else:
raise AttributeError("missing required field 'path'")
@path.setter
def path(self, val):
val = self._path_validator.validate(val)
self._path_value = val
self._path_present = True
@path.deleter
def path(self):
self._path_value = None
self._path_present = False
def __repr__(self):
return 'SaveCopyReferenceArg(copy_reference={!r}, path={!r})'.format(
self._copy_reference_value,
self._path_value,
)
SaveCopyReferenceArg_validator = bv.Struct(SaveCopyReferenceArg)
class SaveCopyReferenceError(bb.Union):
"""
This class acts as a tagged union. Only one of the ``is_*`` methods will
return true. To get the associated value of a tag (if one exists), use the
corresponding ``get_*`` method.
:ivar invalid_copy_reference: The copy reference is invalid.
:ivar no_permission: You don't have permission to save the given copy
reference. Please make sure this app is same app which created the copy
reference and the source user is still linked to the app.
:ivar not_found: The file referenced by the copy reference cannot be found.
:ivar too_many_files: The operation would involve more than 10,000 files and
folders.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
invalid_copy_reference = None
# Attribute is overwritten below the class definition
no_permission = None
# Attribute is overwritten below the class definition
not_found = None
# Attribute is overwritten below the class definition
too_many_files = 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 WriteError val:
:rtype: SaveCopyReferenceError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_invalid_copy_reference(self):
"""
Check if the union tag is ``invalid_copy_reference``.
:rtype: bool
"""
return self._tag == 'invalid_copy_reference'
def is_no_permission(self):
"""
Check if the union tag is ``no_permission``.
:rtype: bool
"""
return self._tag == 'no_permission'
def is_not_found(self):
"""
Check if the union tag is ``not_found``.
:rtype: bool
"""
return self._tag == 'not_found'
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_path(self):
"""
Only call this if :meth:`is_path` is true.
:rtype: WriteError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'SaveCopyReferenceError(%r, %r)' % (self._tag, self._value)
SaveCopyReferenceError_validator = bv.Union(SaveCopyReferenceError)
class SaveCopyReferenceResult(object):
"""
:ivar metadata: The metadata of the saved file or folder in the user's
Dropbox.
"""
__slots__ = [
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
metadata=None):
self._metadata_value = None
self._metadata_present = False
if metadata is not None:
self.metadata = metadata
@property
def metadata(self):
"""
The metadata of the saved file or folder in the user's Dropbox.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'SaveCopyReferenceResult(metadata={!r})'.format(
self._metadata_value,
)
SaveCopyReferenceResult_validator = bv.Struct(SaveCopyReferenceResult)
class SaveUrlArg(object):
"""
:ivar path: The path in Dropbox where the URL will be saved to.
:ivar url: The URL to be saved.
"""
__slots__ = [
'_path_value',
'_path_present',
'_url_value',
'_url_present',
]
_has_required_fields = True
def __init__(self,
path=None,
url=None):
self._path_value = None
self._path_present = False
self._url_value = None
self._url_present = False
if path is not None:
self.path = path
if url is not None:
self.url = url
@property
def path(self):
"""
The path in Dropbox where the URL will be saved to.
: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 url(self):
"""
The URL to be saved.
:rtype: str
"""
if self._url_present:
return self._url_value
else:
raise AttributeError("missing required field 'url'")
@url.setter
def url(self, val):
val = self._url_validator.validate(val)
self._url_value = val
self._url_present = True
@url.deleter
def url(self):
self._url_value = None
self._url_present = False
def __repr__(self):
return 'SaveUrlArg(path={!r}, url={!r})'.format(
self._path_value,
self._url_value,
)
SaveUrlArg_validator = bv.Struct(SaveUrlArg)
class SaveUrlError(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 download_failed: Failed downloading the given URL.
:ivar invalid_url: The given URL is invalid.
:ivar not_found: The file where the URL is saved to no longer exists.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
download_failed = None
# Attribute is overwritten below the class definition
invalid_url = None
# Attribute is overwritten below the class definition
not_found = 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 WriteError val:
:rtype: SaveUrlError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_download_failed(self):
"""
Check if the union tag is ``download_failed``.
:rtype: bool
"""
return self._tag == 'download_failed'
def is_invalid_url(self):
"""
Check if the union tag is ``invalid_url``.
:rtype: bool
"""
return self._tag == 'invalid_url'
def is_not_found(self):
"""
Check if the union tag is ``not_found``.
:rtype: bool
"""
return self._tag == 'not_found'
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: WriteError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'SaveUrlError(%r, %r)' % (self._tag, self._value)
SaveUrlError_validator = bv.Union(SaveUrlError)
class SaveUrlJobStatus(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 FileMetadata complete: Metadata of the file where the URL is saved to.
"""
@classmethod
def complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param FileMetadata val:
:rtype: SaveUrlJobStatus
"""
return cls('complete', val)
@classmethod
def failed(cls, val):
"""
Create an instance of this class set to the ``failed`` tag with value
``val``.
:param SaveUrlError val:
:rtype: SaveUrlJobStatus
"""
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):
"""
Metadata of the file where the URL is saved to.
Only call this if :meth:`is_complete` is true.
:rtype: FileMetadata
"""
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: SaveUrlError
"""
if not self.is_failed():
raise AttributeError("tag 'failed' not set")
return self._value
def __repr__(self):
return 'SaveUrlJobStatus(%r, %r)' % (self._tag, self._value)
SaveUrlJobStatus_validator = bv.Union(SaveUrlJobStatus)
class SaveUrlResult(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.
:ivar FileMetadata complete: Metadata of the file where the URL is saved to.
"""
@classmethod
def complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param FileMetadata val:
:rtype: SaveUrlResult
"""
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):
"""
Metadata of the file where the URL is saved to.
Only call this if :meth:`is_complete` is true.
:rtype: FileMetadata
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def __repr__(self):
return 'SaveUrlResult(%r, %r)' % (self._tag, self._value)
SaveUrlResult_validator = bv.Union(SaveUrlResult)
class SearchArg(object):
"""
:ivar path: The path in the user's Dropbox to search. Should probably be a
folder.
:ivar query: The string to search for. The search string is split on spaces
into multiple tokens. For file name searching, the last token is used
for prefix matching (i.e. "bat c" matches "bat cave" but not "batman
car").
:ivar start: The starting index within the search results (used for paging).
:ivar max_results: The maximum number of search results to return.
:ivar mode: The search mode (filename, filename_and_content, or
deleted_filename). Note that searching file content is only available
for Dropbox Business accounts.
"""
__slots__ = [
'_path_value',
'_path_present',
'_query_value',
'_query_present',
'_start_value',
'_start_present',
'_max_results_value',
'_max_results_present',
'_mode_value',
'_mode_present',
]
_has_required_fields = True
def __init__(self,
path=None,
query=None,
start=None,
max_results=None,
mode=None):
self._path_value = None
self._path_present = False
self._query_value = None
self._query_present = False
self._start_value = None
self._start_present = False
self._max_results_value = None
self._max_results_present = False
self._mode_value = None
self._mode_present = False
if path is not None:
self.path = path
if query is not None:
self.query = query
if start is not None:
self.start = start
if max_results is not None:
self.max_results = max_results
if mode is not None:
self.mode = mode
@property
def path(self):
"""
The path in the user's Dropbox to search. Should probably be a folder.
: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 query(self):
"""
The string to search for. The search string is split on spaces into
multiple tokens. For file name searching, the last token is used for
prefix matching (i.e. "bat c" matches "bat cave" but not "batman car").
:rtype: str
"""
if self._query_present:
return self._query_value
else:
raise AttributeError("missing required field 'query'")
@query.setter
def query(self, val):
val = self._query_validator.validate(val)
self._query_value = val
self._query_present = True
@query.deleter
def query(self):
self._query_value = None
self._query_present = False
@property
def start(self):
"""
The starting index within the search results (used for paging).
:rtype: long
"""
if self._start_present:
return self._start_value
else:
return 0
@start.setter
def start(self, val):
val = self._start_validator.validate(val)
self._start_value = val
self._start_present = True
@start.deleter
def start(self):
self._start_value = None
self._start_present = False
@property
def max_results(self):
"""
The maximum number of search results to return.
:rtype: long
"""
if self._max_results_present:
return self._max_results_value
else:
return 100
@max_results.setter
def max_results(self, val):
val = self._max_results_validator.validate(val)
self._max_results_value = val
self._max_results_present = True
@max_results.deleter
def max_results(self):
self._max_results_value = None
self._max_results_present = False
@property
def mode(self):
"""
The search mode (filename, filename_and_content, or deleted_filename).
Note that searching file content is only available for Dropbox Business
accounts.
:rtype: SearchMode
"""
if self._mode_present:
return self._mode_value
else:
return SearchMode.filename
@mode.setter
def mode(self, val):
self._mode_validator.validate_type_only(val)
self._mode_value = val
self._mode_present = True
@mode.deleter
def mode(self):
self._mode_value = None
self._mode_present = False
def __repr__(self):
return 'SearchArg(path={!r}, query={!r}, start={!r}, max_results={!r}, mode={!r})'.format(
self._path_value,
self._query_value,
self._start_value,
self._max_results_value,
self._mode_value,
)
SearchArg_validator = bv.Struct(SearchArg)
class SearchError(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 LookupError val:
:rtype: SearchError
"""
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: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'SearchError(%r, %r)' % (self._tag, self._value)
SearchError_validator = bv.Union(SearchError)
class SearchMatch(object):
"""
:ivar match_type: The type of the match.
:ivar metadata: The metadata for the matched file or folder.
"""
__slots__ = [
'_match_type_value',
'_match_type_present',
'_metadata_value',
'_metadata_present',
]
_has_required_fields = True
def __init__(self,
match_type=None,
metadata=None):
self._match_type_value = None
self._match_type_present = False
self._metadata_value = None
self._metadata_present = False
if match_type is not None:
self.match_type = match_type
if metadata is not None:
self.metadata = metadata
@property
def match_type(self):
"""
The type of the match.
:rtype: SearchMatchType
"""
if self._match_type_present:
return self._match_type_value
else:
raise AttributeError("missing required field 'match_type'")
@match_type.setter
def match_type(self, val):
self._match_type_validator.validate_type_only(val)
self._match_type_value = val
self._match_type_present = True
@match_type.deleter
def match_type(self):
self._match_type_value = None
self._match_type_present = False
@property
def metadata(self):
"""
The metadata for the matched file or folder.
:rtype: Metadata
"""
if self._metadata_present:
return self._metadata_value
else:
raise AttributeError("missing required field 'metadata'")
@metadata.setter
def metadata(self, val):
self._metadata_validator.validate_type_only(val)
self._metadata_value = val
self._metadata_present = True
@metadata.deleter
def metadata(self):
self._metadata_value = None
self._metadata_present = False
def __repr__(self):
return 'SearchMatch(match_type={!r}, metadata={!r})'.format(
self._match_type_value,
self._metadata_value,
)
SearchMatch_validator = bv.Struct(SearchMatch)
class SearchMatchType(bb.Union):
"""
Indicates what type of match was found for a given item.
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 filename: This item was matched on its file or folder name.
:ivar content: This item was matched based on its file contents.
:ivar both: This item was matched based on both its contents and its file
name.
"""
_catch_all = None
# Attribute is overwritten below the class definition
filename = None
# Attribute is overwritten below the class definition
content = None
# Attribute is overwritten below the class definition
both = None
def is_filename(self):
"""
Check if the union tag is ``filename``.
:rtype: bool
"""
return self._tag == 'filename'
def is_content(self):
"""
Check if the union tag is ``content``.
:rtype: bool
"""
return self._tag == 'content'
def is_both(self):
"""
Check if the union tag is ``both``.
:rtype: bool
"""
return self._tag == 'both'
def __repr__(self):
return 'SearchMatchType(%r, %r)' % (self._tag, self._value)
SearchMatchType_validator = bv.Union(SearchMatchType)
class SearchMode(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 filename: Search file and folder names.
:ivar filename_and_content: Search file and folder names as well as file
contents.
:ivar deleted_filename: Search for deleted file and folder names.
"""
_catch_all = None
# Attribute is overwritten below the class definition
filename = None
# Attribute is overwritten below the class definition
filename_and_content = None
# Attribute is overwritten below the class definition
deleted_filename = None
def is_filename(self):
"""
Check if the union tag is ``filename``.
:rtype: bool
"""
return self._tag == 'filename'
def is_filename_and_content(self):
"""
Check if the union tag is ``filename_and_content``.
:rtype: bool
"""
return self._tag == 'filename_and_content'
def is_deleted_filename(self):
"""
Check if the union tag is ``deleted_filename``.
:rtype: bool
"""
return self._tag == 'deleted_filename'
def __repr__(self):
return 'SearchMode(%r, %r)' % (self._tag, self._value)
SearchMode_validator = bv.Union(SearchMode)
class SearchResult(object):
"""
:ivar matches: A list (possibly empty) of matches for the query.
:ivar more: Used for paging. If true, indicates there is another page of
results available that can be fetched by calling
:meth:`dropbox.dropbox.Dropbox.files_search` again.
:ivar start: Used for paging. Value to set the start argument to when
calling :meth:`dropbox.dropbox.Dropbox.files_search` to fetch the next
page of results.
"""
__slots__ = [
'_matches_value',
'_matches_present',
'_more_value',
'_more_present',
'_start_value',
'_start_present',
]
_has_required_fields = True
def __init__(self,
matches=None,
more=None,
start=None):
self._matches_value = None
self._matches_present = False
self._more_value = None
self._more_present = False
self._start_value = None
self._start_present = False
if matches is not None:
self.matches = matches
if more is not None:
self.more = more
if start is not None:
self.start = start
@property
def matches(self):
"""
A list (possibly empty) of matches for the query.
:rtype: list of [SearchMatch]
"""
if self._matches_present:
return self._matches_value
else:
raise AttributeError("missing required field 'matches'")
@matches.setter
def matches(self, val):
val = self._matches_validator.validate(val)
self._matches_value = val
self._matches_present = True
@matches.deleter
def matches(self):
self._matches_value = None
self._matches_present = False
@property
def more(self):
"""
Used for paging. If true, indicates there is another page of results
available that can be fetched by calling
:meth:`dropbox.dropbox.Dropbox.files_search` again.
:rtype: bool
"""
if self._more_present:
return self._more_value
else:
raise AttributeError("missing required field 'more'")
@more.setter
def more(self, val):
val = self._more_validator.validate(val)
self._more_value = val
self._more_present = True
@more.deleter
def more(self):
self._more_value = None
self._more_present = False
@property
def start(self):
"""
Used for paging. Value to set the start argument to when calling
:meth:`dropbox.dropbox.Dropbox.files_search` to fetch the next page of
results.
:rtype: long
"""
if self._start_present:
return self._start_value
else:
raise AttributeError("missing required field 'start'")
@start.setter
def start(self, val):
val = self._start_validator.validate(val)
self._start_value = val
self._start_present = True
@start.deleter
def start(self):
self._start_value = None
self._start_present = False
def __repr__(self):
return 'SearchResult(matches={!r}, more={!r}, start={!r})'.format(
self._matches_value,
self._more_value,
self._start_value,
)
SearchResult_validator = bv.Struct(SearchResult)
class SharedLink(object):
"""
:ivar url: Shared link url.
:ivar password: Password for the shared link.
"""
__slots__ = [
'_url_value',
'_url_present',
'_password_value',
'_password_present',
]
_has_required_fields = True
def __init__(self,
url=None,
password=None):
self._url_value = None
self._url_present = False
self._password_value = None
self._password_present = False
if url is not None:
self.url = url
if password is not None:
self.password = password
@property
def url(self):
"""
Shared link url.
: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 password(self):
"""
Password for the shared link.
:rtype: str
"""
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
val = self._password_validator.validate(val)
self._password_value = val
self._password_present = True
@password.deleter
def password(self):
self._password_value = None
self._password_present = False
def __repr__(self):
return 'SharedLink(url={!r}, password={!r})'.format(
self._url_value,
self._password_value,
)
SharedLink_validator = bv.Struct(SharedLink)
class ThumbnailArg(object):
"""
:ivar path: The path to the image file you want to thumbnail.
:ivar format: The format for the thumbnail image, jpeg (default) or png. For
images that are photos, jpeg should be preferred, while png is better
for screenshots and digital arts.
:ivar size: The size for the thumbnail image.
"""
__slots__ = [
'_path_value',
'_path_present',
'_format_value',
'_format_present',
'_size_value',
'_size_present',
]
_has_required_fields = True
def __init__(self,
path=None,
format=None,
size=None):
self._path_value = None
self._path_present = False
self._format_value = None
self._format_present = False
self._size_value = None
self._size_present = False
if path is not None:
self.path = path
if format is not None:
self.format = format
if size is not None:
self.size = size
@property
def path(self):
"""
The path to the image file you want to thumbnail.
: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 format(self):
"""
The format for the thumbnail image, jpeg (default) or png. For images
that are photos, jpeg should be preferred, while png is better for
screenshots and digital arts.
:rtype: ThumbnailFormat
"""
if self._format_present:
return self._format_value
else:
return ThumbnailFormat.jpeg
@format.setter
def format(self, val):
self._format_validator.validate_type_only(val)
self._format_value = val
self._format_present = True
@format.deleter
def format(self):
self._format_value = None
self._format_present = False
@property
def size(self):
"""
The size for the thumbnail image.
:rtype: ThumbnailSize
"""
if self._size_present:
return self._size_value
else:
return ThumbnailSize.w64h64
@size.setter
def size(self, val):
self._size_validator.validate_type_only(val)
self._size_value = val
self._size_present = True
@size.deleter
def size(self):
self._size_value = None
self._size_present = False
def __repr__(self):
return 'ThumbnailArg(path={!r}, format={!r}, size={!r})'.format(
self._path_value,
self._format_value,
self._size_value,
)
ThumbnailArg_validator = bv.Struct(ThumbnailArg)
class ThumbnailError(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 LookupError path: An error occurs when downloading metadata for the
image.
:ivar unsupported_extension: The file extension doesn't allow conversion to
a thumbnail.
:ivar unsupported_image: The image cannot be converted to a thumbnail.
:ivar conversion_error: An error occurs during thumbnail conversion.
"""
_catch_all = None
# Attribute is overwritten below the class definition
unsupported_extension = None
# Attribute is overwritten below the class definition
unsupported_image = None
# Attribute is overwritten below the class definition
conversion_error = None
@classmethod
def path(cls, val):
"""
Create an instance of this class set to the ``path`` tag with value
``val``.
:param LookupError val:
:rtype: ThumbnailError
"""
return cls('path', val)
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_unsupported_extension(self):
"""
Check if the union tag is ``unsupported_extension``.
:rtype: bool
"""
return self._tag == 'unsupported_extension'
def is_unsupported_image(self):
"""
Check if the union tag is ``unsupported_image``.
:rtype: bool
"""
return self._tag == 'unsupported_image'
def is_conversion_error(self):
"""
Check if the union tag is ``conversion_error``.
:rtype: bool
"""
return self._tag == 'conversion_error'
def get_path(self):
"""
An error occurs when downloading metadata for the image.
Only call this if :meth:`is_path` is true.
:rtype: LookupError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'ThumbnailError(%r, %r)' % (self._tag, self._value)
ThumbnailError_validator = bv.Union(ThumbnailError)
class ThumbnailFormat(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 = None
# Attribute is overwritten below the class definition
jpeg = None
# Attribute is overwritten below the class definition
png = None
def is_jpeg(self):
"""
Check if the union tag is ``jpeg``.
:rtype: bool
"""
return self._tag == 'jpeg'
def is_png(self):
"""
Check if the union tag is ``png``.
:rtype: bool
"""
return self._tag == 'png'
def __repr__(self):
return 'ThumbnailFormat(%r, %r)' % (self._tag, self._value)
ThumbnailFormat_validator = bv.Union(ThumbnailFormat)
class ThumbnailSize(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 w32h32: 32 by 32 px.
:ivar w64h64: 64 by 64 px.
:ivar w128h128: 128 by 128 px.
:ivar w640h480: 640 by 480 px.
:ivar w1024h768: 1024 by 768.
"""
_catch_all = None
# Attribute is overwritten below the class definition
w32h32 = None
# Attribute is overwritten below the class definition
w64h64 = None
# Attribute is overwritten below the class definition
w128h128 = None
# Attribute is overwritten below the class definition
w640h480 = None
# Attribute is overwritten below the class definition
w1024h768 = None
def is_w32h32(self):
"""
Check if the union tag is ``w32h32``.
:rtype: bool
"""
return self._tag == 'w32h32'
def is_w64h64(self):
"""
Check if the union tag is ``w64h64``.
:rtype: bool
"""
return self._tag == 'w64h64'
def is_w128h128(self):
"""
Check if the union tag is ``w128h128``.
:rtype: bool
"""
return self._tag == 'w128h128'
def is_w640h480(self):
"""
Check if the union tag is ``w640h480``.
:rtype: bool
"""
return self._tag == 'w640h480'
def is_w1024h768(self):
"""
Check if the union tag is ``w1024h768``.
:rtype: bool
"""
return self._tag == 'w1024h768'
def __repr__(self):
return 'ThumbnailSize(%r, %r)' % (self._tag, self._value)
ThumbnailSize_validator = bv.Union(ThumbnailSize)
class UploadError(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 UploadWriteFailed path: Unable to save the uploaded contents to a
file.
"""
_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 UploadWriteFailed val:
:rtype: UploadError
"""
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):
"""
Unable to save the uploaded contents to a file.
Only call this if :meth:`is_path` is true.
:rtype: UploadWriteFailed
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'UploadError(%r, %r)' % (self._tag, self._value)
UploadError_validator = bv.Union(UploadError)
class UploadErrorWithProperties(UploadError):
"""
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 properties_error(cls, val):
"""
Create an instance of this class set to the ``properties_error`` tag
with value ``val``.
:param file_properties.InvalidPropertyGroupError_validator val:
:rtype: UploadErrorWithProperties
"""
return cls('properties_error', val)
def is_properties_error(self):
"""
Check if the union tag is ``properties_error``.
:rtype: bool
"""
return self._tag == 'properties_error'
def get_properties_error(self):
"""
Only call this if :meth:`is_properties_error` is true.
:rtype: file_properties.InvalidPropertyGroupError_validator
"""
if not self.is_properties_error():
raise AttributeError("tag 'properties_error' not set")
return self._value
def __repr__(self):
return 'UploadErrorWithProperties(%r, %r)' % (self._tag, self._value)
UploadErrorWithProperties_validator = bv.Union(UploadErrorWithProperties)
class UploadSessionAppendArg(object):
"""
:ivar cursor: Contains the upload session ID and the offset.
:ivar close: If true, the current session will be closed, at which point you
won't be able to call
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` anymore
with the current session.
"""
__slots__ = [
'_cursor_value',
'_cursor_present',
'_close_value',
'_close_present',
]
_has_required_fields = True
def __init__(self,
cursor=None,
close=None):
self._cursor_value = None
self._cursor_present = False
self._close_value = None
self._close_present = False
if cursor is not None:
self.cursor = cursor
if close is not None:
self.close = close
@property
def cursor(self):
"""
Contains the upload session ID and the offset.
:rtype: UploadSessionCursor
"""
if self._cursor_present:
return self._cursor_value
else:
raise AttributeError("missing required field 'cursor'")
@cursor.setter
def cursor(self, val):
self._cursor_validator.validate_type_only(val)
self._cursor_value = val
self._cursor_present = True
@cursor.deleter
def cursor(self):
self._cursor_value = None
self._cursor_present = False
@property
def close(self):
"""
If true, the current session will be closed, at which point you won't be
able to call
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` anymore
with the current session.
:rtype: bool
"""
if self._close_present:
return self._close_value
else:
return False
@close.setter
def close(self, val):
val = self._close_validator.validate(val)
self._close_value = val
self._close_present = True
@close.deleter
def close(self):
self._close_value = None
self._close_present = False
def __repr__(self):
return 'UploadSessionAppendArg(cursor={!r}, close={!r})'.format(
self._cursor_value,
self._close_value,
)
UploadSessionAppendArg_validator = bv.Struct(UploadSessionAppendArg)
class UploadSessionCursor(object):
"""
:ivar session_id: The upload session ID (returned by
:meth:`dropbox.dropbox.Dropbox.files_upload_session_start`).
:ivar offset: The amount of data that has been uploaded so far. We use this
to make sure upload data isn't lost or duplicated in the event of a
network error.
"""
__slots__ = [
'_session_id_value',
'_session_id_present',
'_offset_value',
'_offset_present',
]
_has_required_fields = True
def __init__(self,
session_id=None,
offset=None):
self._session_id_value = None
self._session_id_present = False
self._offset_value = None
self._offset_present = False
if session_id is not None:
self.session_id = session_id
if offset is not None:
self.offset = offset
@property
def session_id(self):
"""
The upload session ID (returned by
:meth:`dropbox.dropbox.Dropbox.files_upload_session_start`).
:rtype: str
"""
if self._session_id_present:
return self._session_id_value
else:
raise AttributeError("missing required field 'session_id'")
@session_id.setter
def session_id(self, val):
val = self._session_id_validator.validate(val)
self._session_id_value = val
self._session_id_present = True
@session_id.deleter
def session_id(self):
self._session_id_value = None
self._session_id_present = False
@property
def offset(self):
"""
The amount of data that has been uploaded so far. We use this to make
sure upload data isn't lost or duplicated in the event of a network
error.
:rtype: long
"""
if self._offset_present:
return self._offset_value
else:
raise AttributeError("missing required field 'offset'")
@offset.setter
def offset(self, val):
val = self._offset_validator.validate(val)
self._offset_value = val
self._offset_present = True
@offset.deleter
def offset(self):
self._offset_value = None
self._offset_present = False
def __repr__(self):
return 'UploadSessionCursor(session_id={!r}, offset={!r})'.format(
self._session_id_value,
self._offset_value,
)
UploadSessionCursor_validator = bv.Struct(UploadSessionCursor)
class UploadSessionFinishArg(object):
"""
:ivar cursor: Contains the upload session ID and the offset.
:ivar commit: Contains the path and other optional modifiers for the commit.
"""
__slots__ = [
'_cursor_value',
'_cursor_present',
'_commit_value',
'_commit_present',
]
_has_required_fields = True
def __init__(self,
cursor=None,
commit=None):
self._cursor_value = None
self._cursor_present = False
self._commit_value = None
self._commit_present = False
if cursor is not None:
self.cursor = cursor
if commit is not None:
self.commit = commit
@property
def cursor(self):
"""
Contains the upload session ID and the offset.
:rtype: UploadSessionCursor
"""
if self._cursor_present:
return self._cursor_value
else:
raise AttributeError("missing required field 'cursor'")
@cursor.setter
def cursor(self, val):
self._cursor_validator.validate_type_only(val)
self._cursor_value = val
self._cursor_present = True
@cursor.deleter
def cursor(self):
self._cursor_value = None
self._cursor_present = False
@property
def commit(self):
"""
Contains the path and other optional modifiers for the commit.
:rtype: CommitInfo
"""
if self._commit_present:
return self._commit_value
else:
raise AttributeError("missing required field 'commit'")
@commit.setter
def commit(self, val):
self._commit_validator.validate_type_only(val)
self._commit_value = val
self._commit_present = True
@commit.deleter
def commit(self):
self._commit_value = None
self._commit_present = False
def __repr__(self):
return 'UploadSessionFinishArg(cursor={!r}, commit={!r})'.format(
self._cursor_value,
self._commit_value,
)
UploadSessionFinishArg_validator = bv.Struct(UploadSessionFinishArg)
class UploadSessionFinishBatchArg(object):
"""
:ivar entries: Commit information for each file in the batch.
"""
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
Commit information for each file in the batch.
:rtype: list of [UploadSessionFinishArg]
"""
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
def __repr__(self):
return 'UploadSessionFinishBatchArg(entries={!r})'.format(
self._entries_value,
)
UploadSessionFinishBatchArg_validator = bv.Struct(UploadSessionFinishBatchArg)
class UploadSessionFinishBatchJobStatus(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 UploadSessionFinishBatchResult complete: The
:meth:`dropbox.dropbox.Dropbox.files_upload_session_finish_batch` has
finished.
"""
@classmethod
def complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param UploadSessionFinishBatchResult val:
:rtype: UploadSessionFinishBatchJobStatus
"""
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):
"""
The :meth:`dropbox.dropbox.Dropbox.files_upload_session_finish_batch`
has finished.
Only call this if :meth:`is_complete` is true.
:rtype: UploadSessionFinishBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def __repr__(self):
return 'UploadSessionFinishBatchJobStatus(%r, %r)' % (self._tag, self._value)
UploadSessionFinishBatchJobStatus_validator = bv.Union(UploadSessionFinishBatchJobStatus)
class UploadSessionFinishBatchLaunch(async.LaunchResultBase):
"""
Result returned by
:meth:`dropbox.dropbox.Dropbox.files_upload_session_finish_batch` that may
either launch an asynchronous job or complete synchronously.
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 complete(cls, val):
"""
Create an instance of this class set to the ``complete`` tag with value
``val``.
:param UploadSessionFinishBatchResult val:
:rtype: UploadSessionFinishBatchLaunch
"""
return cls('complete', val)
def is_complete(self):
"""
Check if the union tag is ``complete``.
:rtype: bool
"""
return self._tag == 'complete'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_complete(self):
"""
Only call this if :meth:`is_complete` is true.
:rtype: UploadSessionFinishBatchResult
"""
if not self.is_complete():
raise AttributeError("tag 'complete' not set")
return self._value
def __repr__(self):
return 'UploadSessionFinishBatchLaunch(%r, %r)' % (self._tag, self._value)
UploadSessionFinishBatchLaunch_validator = bv.Union(UploadSessionFinishBatchLaunch)
class UploadSessionFinishBatchResult(object):
"""
:ivar entries: Commit result for each file in the batch.
"""
__slots__ = [
'_entries_value',
'_entries_present',
]
_has_required_fields = True
def __init__(self,
entries=None):
self._entries_value = None
self._entries_present = False
if entries is not None:
self.entries = entries
@property
def entries(self):
"""
Commit result for each file in the batch.
:rtype: list of [UploadSessionFinishBatchResultEntry]
"""
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
def __repr__(self):
return 'UploadSessionFinishBatchResult(entries={!r})'.format(
self._entries_value,
)
UploadSessionFinishBatchResult_validator = bv.Struct(UploadSessionFinishBatchResult)
class UploadSessionFinishBatchResultEntry(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 = None
@classmethod
def success(cls, val):
"""
Create an instance of this class set to the ``success`` tag with value
``val``.
:param FileMetadata val:
:rtype: UploadSessionFinishBatchResultEntry
"""
return cls('success', val)
@classmethod
def failure(cls, val):
"""
Create an instance of this class set to the ``failure`` tag with value
``val``.
:param UploadSessionFinishError val:
:rtype: UploadSessionFinishBatchResultEntry
"""
return cls('failure', val)
def is_success(self):
"""
Check if the union tag is ``success``.
:rtype: bool
"""
return self._tag == 'success'
def is_failure(self):
"""
Check if the union tag is ``failure``.
:rtype: bool
"""
return self._tag == 'failure'
def get_success(self):
"""
Only call this if :meth:`is_success` is true.
:rtype: FileMetadata
"""
if not self.is_success():
raise AttributeError("tag 'success' not set")
return self._value
def get_failure(self):
"""
Only call this if :meth:`is_failure` is true.
:rtype: UploadSessionFinishError
"""
if not self.is_failure():
raise AttributeError("tag 'failure' not set")
return self._value
def __repr__(self):
return 'UploadSessionFinishBatchResultEntry(%r, %r)' % (self._tag, self._value)
UploadSessionFinishBatchResultEntry_validator = bv.Union(UploadSessionFinishBatchResultEntry)
class UploadSessionFinishError(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 UploadSessionLookupError lookup_failed: The session arguments are
incorrect; the value explains the reason.
:ivar WriteError path: Unable to save the uploaded contents to a file.
:ivar too_many_shared_folder_targets: The batch request commits files into
too many different shared folders. Please limit your batch request to
files contained in a single shared folder.
:ivar too_many_write_operations: There are too many write operations
happening in the user's Dropbox. You should retry uploading this file.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
too_many_shared_folder_targets = None
# Attribute is overwritten below the class definition
too_many_write_operations = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def lookup_failed(cls, val):
"""
Create an instance of this class set to the ``lookup_failed`` tag with
value ``val``.
:param UploadSessionLookupError val:
:rtype: UploadSessionFinishError
"""
return cls('lookup_failed', val)
@classmethod
def path(cls, val):
"""
Create an instance of this class set to the ``path`` tag with value
``val``.
:param WriteError val:
:rtype: UploadSessionFinishError
"""
return cls('path', val)
def is_lookup_failed(self):
"""
Check if the union tag is ``lookup_failed``.
:rtype: bool
"""
return self._tag == 'lookup_failed'
def is_path(self):
"""
Check if the union tag is ``path``.
:rtype: bool
"""
return self._tag == 'path'
def is_too_many_shared_folder_targets(self):
"""
Check if the union tag is ``too_many_shared_folder_targets``.
:rtype: bool
"""
return self._tag == 'too_many_shared_folder_targets'
def is_too_many_write_operations(self):
"""
Check if the union tag is ``too_many_write_operations``.
:rtype: bool
"""
return self._tag == 'too_many_write_operations'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_lookup_failed(self):
"""
The session arguments are incorrect; the value explains the reason.
Only call this if :meth:`is_lookup_failed` is true.
:rtype: UploadSessionLookupError
"""
if not self.is_lookup_failed():
raise AttributeError("tag 'lookup_failed' not set")
return self._value
def get_path(self):
"""
Unable to save the uploaded contents to a file.
Only call this if :meth:`is_path` is true.
:rtype: WriteError
"""
if not self.is_path():
raise AttributeError("tag 'path' not set")
return self._value
def __repr__(self):
return 'UploadSessionFinishError(%r, %r)' % (self._tag, self._value)
UploadSessionFinishError_validator = bv.Union(UploadSessionFinishError)
class UploadSessionLookupError(bb.Union):
"""
This class acts as a tagged union. Only one of the ``is_*`` methods will
return true. To get the associated value of a tag (if one exists), use the
corresponding ``get_*`` method.
:ivar not_found: The upload session ID was not found or has expired. Upload
sessions are valid for 48 hours.
:ivar UploadSessionOffsetError incorrect_offset: The specified offset was
incorrect. See the value for the correct offset. This error may occur
when a previous request was received and processed successfully but the
client did not receive the response, e.g. due to a network error.
:ivar closed: You are attempting to append data to an upload session that
has alread been closed (i.e. committed).
:ivar not_closed: The session must be closed before calling
upload_session/finish_batch.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
not_found = None
# Attribute is overwritten below the class definition
closed = None
# Attribute is overwritten below the class definition
not_closed = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def incorrect_offset(cls, val):
"""
Create an instance of this class set to the ``incorrect_offset`` tag
with value ``val``.
:param UploadSessionOffsetError val:
:rtype: UploadSessionLookupError
"""
return cls('incorrect_offset', val)
def is_not_found(self):
"""
Check if the union tag is ``not_found``.
:rtype: bool
"""
return self._tag == 'not_found'
def is_incorrect_offset(self):
"""
Check if the union tag is ``incorrect_offset``.
:rtype: bool
"""
return self._tag == 'incorrect_offset'
def is_closed(self):
"""
Check if the union tag is ``closed``.
:rtype: bool
"""
return self._tag == 'closed'
def is_not_closed(self):
"""
Check if the union tag is ``not_closed``.
:rtype: bool
"""
return self._tag == 'not_closed'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def get_incorrect_offset(self):
"""
The specified offset was incorrect. See the value for the correct
offset. This error may occur when a previous request was received and
processed successfully but the client did not receive the response, e.g.
due to a network error.
Only call this if :meth:`is_incorrect_offset` is true.
:rtype: UploadSessionOffsetError
"""
if not self.is_incorrect_offset():
raise AttributeError("tag 'incorrect_offset' not set")
return self._value
def __repr__(self):
return 'UploadSessionLookupError(%r, %r)' % (self._tag, self._value)
UploadSessionLookupError_validator = bv.Union(UploadSessionLookupError)
class UploadSessionOffsetError(object):
"""
:ivar correct_offset: The offset up to which data has been collected.
"""
__slots__ = [
'_correct_offset_value',
'_correct_offset_present',
]
_has_required_fields = True
def __init__(self,
correct_offset=None):
self._correct_offset_value = None
self._correct_offset_present = False
if correct_offset is not None:
self.correct_offset = correct_offset
@property
def correct_offset(self):
"""
The offset up to which data has been collected.
:rtype: long
"""
if self._correct_offset_present:
return self._correct_offset_value
else:
raise AttributeError("missing required field 'correct_offset'")
@correct_offset.setter
def correct_offset(self, val):
val = self._correct_offset_validator.validate(val)
self._correct_offset_value = val
self._correct_offset_present = True
@correct_offset.deleter
def correct_offset(self):
self._correct_offset_value = None
self._correct_offset_present = False
def __repr__(self):
return 'UploadSessionOffsetError(correct_offset={!r})'.format(
self._correct_offset_value,
)
UploadSessionOffsetError_validator = bv.Struct(UploadSessionOffsetError)
class UploadSessionStartArg(object):
"""
:ivar close: If true, the current session will be closed, at which point you
won't be able to call
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` anymore
with the current session.
"""
__slots__ = [
'_close_value',
'_close_present',
]
_has_required_fields = False
def __init__(self,
close=None):
self._close_value = None
self._close_present = False
if close is not None:
self.close = close
@property
def close(self):
"""
If true, the current session will be closed, at which point you won't be
able to call
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` anymore
with the current session.
:rtype: bool
"""
if self._close_present:
return self._close_value
else:
return False
@close.setter
def close(self, val):
val = self._close_validator.validate(val)
self._close_value = val
self._close_present = True
@close.deleter
def close(self):
self._close_value = None
self._close_present = False
def __repr__(self):
return 'UploadSessionStartArg(close={!r})'.format(
self._close_value,
)
UploadSessionStartArg_validator = bv.Struct(UploadSessionStartArg)
class UploadSessionStartResult(object):
"""
:ivar session_id: A unique identifier for the upload session. Pass this to
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` and
:meth:`dropbox.dropbox.Dropbox.files_upload_session_finish`.
"""
__slots__ = [
'_session_id_value',
'_session_id_present',
]
_has_required_fields = True
def __init__(self,
session_id=None):
self._session_id_value = None
self._session_id_present = False
if session_id is not None:
self.session_id = session_id
@property
def session_id(self):
"""
A unique identifier for the upload session. Pass this to
:meth:`dropbox.dropbox.Dropbox.files_upload_session_append_v2` and
:meth:`dropbox.dropbox.Dropbox.files_upload_session_finish`.
:rtype: str
"""
if self._session_id_present:
return self._session_id_value
else:
raise AttributeError("missing required field 'session_id'")
@session_id.setter
def session_id(self, val):
val = self._session_id_validator.validate(val)
self._session_id_value = val
self._session_id_present = True
@session_id.deleter
def session_id(self):
self._session_id_value = None
self._session_id_present = False
def __repr__(self):
return 'UploadSessionStartResult(session_id={!r})'.format(
self._session_id_value,
)
UploadSessionStartResult_validator = bv.Struct(UploadSessionStartResult)
class UploadWriteFailed(object):
"""
:ivar reason: The reason why the file couldn't be saved.
:ivar upload_session_id: The upload session ID; this may be used to retry
the commit.
"""
__slots__ = [
'_reason_value',
'_reason_present',
'_upload_session_id_value',
'_upload_session_id_present',
]
_has_required_fields = True
def __init__(self,
reason=None,
upload_session_id=None):
self._reason_value = None
self._reason_present = False
self._upload_session_id_value = None
self._upload_session_id_present = False
if reason is not None:
self.reason = reason
if upload_session_id is not None:
self.upload_session_id = upload_session_id
@property
def reason(self):
"""
The reason why the file couldn't be saved.
:rtype: WriteError
"""
if self._reason_present:
return self._reason_value
else:
raise AttributeError("missing required field 'reason'")
@reason.setter
def reason(self, val):
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
@property
def upload_session_id(self):
"""
The upload session ID; this may be used to retry the commit.
:rtype: str
"""
if self._upload_session_id_present:
return self._upload_session_id_value
else:
raise AttributeError("missing required field 'upload_session_id'")
@upload_session_id.setter
def upload_session_id(self, val):
val = self._upload_session_id_validator.validate(val)
self._upload_session_id_value = val
self._upload_session_id_present = True
@upload_session_id.deleter
def upload_session_id(self):
self._upload_session_id_value = None
self._upload_session_id_present = False
def __repr__(self):
return 'UploadWriteFailed(reason={!r}, upload_session_id={!r})'.format(
self._reason_value,
self._upload_session_id_value,
)
UploadWriteFailed_validator = bv.Struct(UploadWriteFailed)
class VideoMetadata(MediaMetadata):
"""
Metadata for a video.
:ivar duration: The duration of the video in milliseconds.
"""
__slots__ = [
'_duration_value',
'_duration_present',
]
_has_required_fields = False
def __init__(self,
dimensions=None,
location=None,
time_taken=None,
duration=None):
super(VideoMetadata, self).__init__(dimensions,
location,
time_taken)
self._duration_value = None
self._duration_present = False
if duration is not None:
self.duration = duration
@property
def duration(self):
"""
The duration of the video in milliseconds.
:rtype: long
"""
if self._duration_present:
return self._duration_value
else:
return None
@duration.setter
def duration(self, val):
if val is None:
del self.duration
return
val = self._duration_validator.validate(val)
self._duration_value = val
self._duration_present = True
@duration.deleter
def duration(self):
self._duration_value = None
self._duration_present = False
def __repr__(self):
return 'VideoMetadata(dimensions={!r}, location={!r}, time_taken={!r}, duration={!r})'.format(
self._dimensions_value,
self._location_value,
self._time_taken_value,
self._duration_value,
)
VideoMetadata_validator = bv.Struct(VideoMetadata)
class WriteConflictError(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 file: There's a file in the way.
:ivar folder: There's a folder in the way.
:ivar file_ancestor: There's a file at an ancestor path, so we couldn't
create the required parent folders.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
file = None
# Attribute is overwritten below the class definition
folder = None
# Attribute is overwritten below the class definition
file_ancestor = None
# Attribute is overwritten below the class definition
other = 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 is_file_ancestor(self):
"""
Check if the union tag is ``file_ancestor``.
:rtype: bool
"""
return self._tag == 'file_ancestor'
def is_other(self):
"""
Check if the union tag is ``other``.
:rtype: bool
"""
return self._tag == 'other'
def __repr__(self):
return 'WriteConflictError(%r, %r)' % (self._tag, self._value)
WriteConflictError_validator = bv.Union(WriteConflictError)
class WriteError(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 WriteConflictError conflict: Couldn't write to the target path because
there was something in the way.
:ivar no_write_permission: The user doesn't have permissions to write to the
target location.
:ivar insufficient_space: The user doesn't have enough available space
(bytes) to write more data.
:ivar disallowed_name: Dropbox will not save the file or folder because of
its name.
:ivar team_folder: This endpoint cannot move or delete team folders.
"""
_catch_all = 'other'
# Attribute is overwritten below the class definition
no_write_permission = None
# Attribute is overwritten below the class definition
insufficient_space = None
# Attribute is overwritten below the class definition
disallowed_name = None
# Attribute is overwritten below the class definition
team_folder = None
# Attribute is overwritten below the class definition
other = None
@classmethod
def malformed_path(cls, val):
"""
Create an instance of this class set to the ``malformed_path`` tag with
value ``val``.
:param Optional[str] val:
:rtype: WriteError
"""
return cls('malformed_path', val)
@classmethod
def conflict(cls, val):
"""
Create an instance of this class set to the ``conflict`` tag with value
``val``.
:param WriteConflictError val:
:rtype: WriteError
"""
return cls('conflict', val)
def is_malformed_path(self):
"""
Check if the union tag is ``malformed_path``.
:rtype: bool
"""
return self._tag == 'malformed_path'
def is_conflict(self):
"""
Check if the union tag is ``conflict``.
:rtype: bool
"""
return self._tag == 'conflict'
def is_no_write_permission(self):
"""
Check if the union tag is ``no_write_permission``.
:rtype: bool
"""
return self._tag == 'no_write_permission'
def is_insufficient_space(self):
"""
Check if the union tag is ``insufficient_space``.
:rtype: bool
"""
return self._tag == 'insufficient_space'
def is_disallowed_name(self):
"""
Check if the union tag is ``disallowed_name``.
:rtype: bool
"""
return self._tag == 'disallowed_name'
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_malformed_path(self):
"""
Only call this if :meth:`is_malformed_path` is true.
:rtype: Optional[str]
"""
if not self.is_malformed_path():
raise AttributeError("tag 'malformed_path' not set")
return self._value
def get_conflict(self):
"""
Couldn't write to the target path because there was something in the
way.
Only call this if :meth:`is_conflict` is true.
:rtype: WriteConflictError
"""
if not self.is_conflict():
raise AttributeError("tag 'conflict' not set")
return self._value
def __repr__(self):
return 'WriteError(%r, %r)' % (self._tag, self._value)
WriteError_validator = bv.Union(WriteError)
class WriteMode(bb.Union):
"""
Your intent when writing a file to some path. This is used to determine what
constitutes a conflict and what the autorename strategy is. In some
situations, the conflict behavior is identical: (a) If the target path
doesn't refer to anything, the file is always written; no conflict. (b) If
the target path refers to a folder, it's always a conflict. (c) If the
target path refers to a file with identical contents, nothing gets written;
no conflict. The conflict checking differs in the case where there's a file
at the target path with contents different from the contents you're trying
to write.
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 add: Do not overwrite an existing file if there is a conflict. The
autorename strategy is to append a number to the file name. For example,
"document.txt" might become "document (2).txt".
:ivar overwrite: Always overwrite the existing file. The autorename strategy
is the same as it is for ``add``.
:ivar str update: Overwrite if the given "rev" matches the existing file's
"rev". The autorename strategy is to append the string "conflicted copy"
to the file name. For example, "document.txt" might become "document
(conflicted copy).txt" or "document (Panda's conflicted copy).txt".
"""
_catch_all = None
# Attribute is overwritten below the class definition
add = None
# Attribute is overwritten below the class definition
overwrite = None
@classmethod
def update(cls, val):
"""
Create an instance of this class set to the ``update`` tag with value
``val``.
:param str val:
:rtype: WriteMode
"""
return cls('update', val)
def is_add(self):
"""
Check if the union tag is ``add``.
:rtype: bool
"""
return self._tag == 'add'
def is_overwrite(self):
"""
Check if the union tag is ``overwrite``.
:rtype: bool
"""
return self._tag == 'overwrite'
def is_update(self):
"""
Check if the union tag is ``update``.
:rtype: bool
"""
return self._tag == 'update'
def get_update(self):
"""
Overwrite if the given "rev" matches the existing file's "rev". The
autorename strategy is to append the string "conflicted copy" to the
file name. For example, "document.txt" might become "document
(conflicted copy).txt" or "document (Panda's conflicted copy).txt".
Only call this if :meth:`is_update` is true.
:rtype: str
"""
if not self.is_update():
raise AttributeError("tag 'update' not set")
return self._value
def __repr__(self):
return 'WriteMode(%r, %r)' % (self._tag, self._value)
WriteMode_validator = bv.Union(WriteMode)
Id_validator = bv.String(min_length=1)
ListFolderCursor_validator = bv.String(min_length=1)
MalformedPathError_validator = bv.Nullable(bv.String())
Path_validator = bv.String(pattern=u'/(.|[\\r\\n])*')
PathOrId_validator = bv.String(pattern=u'/(.|[\\r\\n])*|id:.*|(ns:[0-9]+(/.*)?)')
PathR_validator = bv.String(pattern=u'(/(.|[\\r\\n])*)?|(ns:[0-9]+(/.*)?)')
PathROrId_validator = bv.String(pattern=u'(/(.|[\\r\\n])*)?|id:.*|(ns:[0-9]+(/.*)?)')
ReadPath_validator = bv.String(pattern=u'(/(.|[\\r\\n])*|id:.*)|(rev:[0-9a-f]{9,})|(ns:[0-9]+(/.*)?)')
Rev_validator = bv.String(min_length=9, pattern=u'[0-9a-f]+')
Sha256HexHash_validator = bv.String(min_length=64, max_length=64)
SharedLinkUrl_validator = bv.String()
WritePath_validator = bv.String(pattern=u'(/(.|[\\r\\n])*)|(ns:[0-9]+(/.*)?)')
WritePathOrId_validator = bv.String(pattern=u'(/(.|[\\r\\n])*)|(ns:[0-9]+(/.*)?)|(id:.*)')
GetMetadataArg._path_validator = ReadPath_validator
GetMetadataArg._include_media_info_validator = bv.Boolean()
GetMetadataArg._include_deleted_validator = bv.Boolean()
GetMetadataArg._include_has_explicit_shared_members_validator = bv.Boolean()
GetMetadataArg._all_field_names_ = set([
'path',
'include_media_info',
'include_deleted',
'include_has_explicit_shared_members',
])
GetMetadataArg._all_fields_ = [
('path', GetMetadataArg._path_validator),
('include_media_info', GetMetadataArg._include_media_info_validator),
('include_deleted', GetMetadataArg._include_deleted_validator),
('include_has_explicit_shared_members', GetMetadataArg._include_has_explicit_shared_members_validator),
]
AlphaGetMetadataArg._include_property_templates_validator = bv.Nullable(bv.List(file_properties.TemplateId_validator))
AlphaGetMetadataArg._all_field_names_ = GetMetadataArg._all_field_names_.union(set(['include_property_templates']))
AlphaGetMetadataArg._all_fields_ = GetMetadataArg._all_fields_ + [('include_property_templates', AlphaGetMetadataArg._include_property_templates_validator)]
GetMetadataError._path_validator = LookupError_validator
GetMetadataError._tagmap = {
'path': GetMetadataError._path_validator,
}
AlphaGetMetadataError._properties_error_validator = file_properties.LookUpPropertiesError_validator
AlphaGetMetadataError._tagmap = {
'properties_error': AlphaGetMetadataError._properties_error_validator,
}
AlphaGetMetadataError._tagmap.update(GetMetadataError._tagmap)
CommitInfo._path_validator = WritePathOrId_validator
CommitInfo._mode_validator = WriteMode_validator
CommitInfo._autorename_validator = bv.Boolean()
CommitInfo._client_modified_validator = bv.Nullable(common.DropboxTimestamp_validator)
CommitInfo._mute_validator = bv.Boolean()
CommitInfo._all_field_names_ = set([
'path',
'mode',
'autorename',
'client_modified',
'mute',
])
CommitInfo._all_fields_ = [
('path', CommitInfo._path_validator),
('mode', CommitInfo._mode_validator),
('autorename', CommitInfo._autorename_validator),
('client_modified', CommitInfo._client_modified_validator),
('mute', CommitInfo._mute_validator),
]
CommitInfoWithProperties._property_groups_validator = bv.Nullable(bv.List(file_properties.PropertyGroup_validator))
CommitInfoWithProperties._all_field_names_ = CommitInfo._all_field_names_.union(set(['property_groups']))
CommitInfoWithProperties._all_fields_ = CommitInfo._all_fields_ + [('property_groups', CommitInfoWithProperties._property_groups_validator)]
CreateFolderArg._path_validator = WritePath_validator
CreateFolderArg._autorename_validator = bv.Boolean()
CreateFolderArg._all_field_names_ = set([
'path',
'autorename',
])
CreateFolderArg._all_fields_ = [
('path', CreateFolderArg._path_validator),
('autorename', CreateFolderArg._autorename_validator),
]
CreateFolderError._path_validator = WriteError_validator
CreateFolderError._tagmap = {
'path': CreateFolderError._path_validator,
}
FileOpsResult._all_field_names_ = set([])
FileOpsResult._all_fields_ = []
CreateFolderResult._metadata_validator = FolderMetadata_validator
CreateFolderResult._all_field_names_ = FileOpsResult._all_field_names_.union(set(['metadata']))
CreateFolderResult._all_fields_ = FileOpsResult._all_fields_ + [('metadata', CreateFolderResult._metadata_validator)]
DeleteArg._path_validator = WritePathOrId_validator
DeleteArg._all_field_names_ = set(['path'])
DeleteArg._all_fields_ = [('path', DeleteArg._path_validator)]
DeleteBatchArg._entries_validator = bv.List(DeleteArg_validator)
DeleteBatchArg._all_field_names_ = set(['entries'])
DeleteBatchArg._all_fields_ = [('entries', DeleteBatchArg._entries_validator)]
DeleteBatchError._too_many_write_operations_validator = bv.Void()
DeleteBatchError._other_validator = bv.Void()
DeleteBatchError._tagmap = {
'too_many_write_operations': DeleteBatchError._too_many_write_operations_validator,
'other': DeleteBatchError._other_validator,
}
DeleteBatchError.too_many_write_operations = DeleteBatchError('too_many_write_operations')
DeleteBatchError.other = DeleteBatchError('other')
DeleteBatchJobStatus._complete_validator = DeleteBatchResult_validator
DeleteBatchJobStatus._failed_validator = DeleteBatchError_validator
DeleteBatchJobStatus._other_validator = bv.Void()
DeleteBatchJobStatus._tagmap = {
'complete': DeleteBatchJobStatus._complete_validator,
'failed': DeleteBatchJobStatus._failed_validator,
'other': DeleteBatchJobStatus._other_validator,
}
DeleteBatchJobStatus._tagmap.update(async.PollResultBase._tagmap)
DeleteBatchJobStatus.other = DeleteBatchJobStatus('other')
DeleteBatchLaunch._complete_validator = DeleteBatchResult_validator
DeleteBatchLaunch._other_validator = bv.Void()
DeleteBatchLaunch._tagmap = {
'complete': DeleteBatchLaunch._complete_validator,
'other': DeleteBatchLaunch._other_validator,
}
DeleteBatchLaunch._tagmap.update(async.LaunchResultBase._tagmap)
DeleteBatchLaunch.other = DeleteBatchLaunch('other')
DeleteBatchResult._entries_validator = bv.List(DeleteBatchResultEntry_validator)
DeleteBatchResult._all_field_names_ = FileOpsResult._all_field_names_.union(set(['entries']))
DeleteBatchResult._all_fields_ = FileOpsResult._all_fields_ + [('entries', DeleteBatchResult._entries_validator)]
DeleteBatchResultData._metadata_validator = Metadata_validator
DeleteBatchResultData._all_field_names_ = set(['metadata'])
DeleteBatchResultData._all_fields_ = [('metadata', DeleteBatchResultData._metadata_validator)]
DeleteBatchResultEntry._success_validator = DeleteBatchResultData_validator
DeleteBatchResultEntry._failure_validator = DeleteError_validator
DeleteBatchResultEntry._tagmap = {
'success': DeleteBatchResultEntry._success_validator,
'failure': DeleteBatchResultEntry._failure_validator,
}
DeleteError._path_lookup_validator = LookupError_validator
DeleteError._path_write_validator = WriteError_validator
DeleteError._too_many_write_operations_validator = bv.Void()
DeleteError._too_many_files_validator = bv.Void()
DeleteError._other_validator = bv.Void()
DeleteError._tagmap = {
'path_lookup': DeleteError._path_lookup_validator,
'path_write': DeleteError._path_write_validator,
'too_many_write_operations': DeleteError._too_many_write_operations_validator,
'too_many_files': DeleteError._too_many_files_validator,
'other': DeleteError._other_validator,
}
DeleteError.too_many_write_operations = DeleteError('too_many_write_operations')
DeleteError.too_many_files = DeleteError('too_many_files')
DeleteError.other = DeleteError('other')
DeleteResult._metadata_validator = Metadata_validator
DeleteResult._all_field_names_ = FileOpsResult._all_field_names_.union(set(['metadata']))
DeleteResult._all_fields_ = FileOpsResult._all_fields_ + [('metadata', DeleteResult._metadata_validator)]
Metadata._name_validator = bv.String()
Metadata._path_lower_validator = bv.Nullable(bv.String())
Metadata._path_display_validator = bv.Nullable(bv.String())
Metadata._parent_shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator)
Metadata._field_names_ = set([
'name',
'path_lower',
'path_display',
'parent_shared_folder_id',
])
Metadata._all_field_names_ = Metadata._field_names_
Metadata._fields_ = [
('name', Metadata._name_validator),
('path_lower', Metadata._path_lower_validator),
('path_display', Metadata._path_display_validator),
('parent_shared_folder_id', Metadata._parent_shared_folder_id_validator),
]
Metadata._all_fields_ = Metadata._fields_
Metadata._tag_to_subtype_ = {
(u'file',): FileMetadata_validator,
(u'folder',): FolderMetadata_validator,
(u'deleted',): DeletedMetadata_validator,
}
Metadata._pytype_to_tag_and_subtype_ = {
FileMetadata: ((u'file',), FileMetadata_validator),
FolderMetadata: ((u'folder',), FolderMetadata_validator),
DeletedMetadata: ((u'deleted',), DeletedMetadata_validator),
}
Metadata._is_catch_all_ = False
DeletedMetadata._field_names_ = set([])
DeletedMetadata._all_field_names_ = Metadata._all_field_names_.union(DeletedMetadata._field_names_)
DeletedMetadata._fields_ = []
DeletedMetadata._all_fields_ = Metadata._all_fields_ + DeletedMetadata._fields_
Dimensions._height_validator = bv.UInt64()
Dimensions._width_validator = bv.UInt64()
Dimensions._all_field_names_ = set([
'height',
'width',
])
Dimensions._all_fields_ = [
('height', Dimensions._height_validator),
('width', Dimensions._width_validator),
]
DownloadArg._path_validator = ReadPath_validator
DownloadArg._rev_validator = bv.Nullable(Rev_validator)
DownloadArg._all_field_names_ = set([
'path',
'rev',
])
DownloadArg._all_fields_ = [
('path', DownloadArg._path_validator),
('rev', DownloadArg._rev_validator),
]
DownloadError._path_validator = LookupError_validator
DownloadError._other_validator = bv.Void()
DownloadError._tagmap = {
'path': DownloadError._path_validator,
'other': DownloadError._other_validator,
}
DownloadError.other = DownloadError('other')
FileMetadata._id_validator = Id_validator
FileMetadata._client_modified_validator = common.DropboxTimestamp_validator
FileMetadata._server_modified_validator = common.DropboxTimestamp_validator
FileMetadata._rev_validator = Rev_validator
FileMetadata._size_validator = bv.UInt64()
FileMetadata._media_info_validator = bv.Nullable(MediaInfo_validator)
FileMetadata._sharing_info_validator = bv.Nullable(FileSharingInfo_validator)
FileMetadata._property_groups_validator = bv.Nullable(bv.List(file_properties.PropertyGroup_validator))
FileMetadata._has_explicit_shared_members_validator = bv.Nullable(bv.Boolean())
FileMetadata._content_hash_validator = bv.Nullable(Sha256HexHash_validator)
FileMetadata._field_names_ = set([
'id',
'client_modified',
'server_modified',
'rev',
'size',
'media_info',
'sharing_info',
'property_groups',
'has_explicit_shared_members',
'content_hash',
])
FileMetadata._all_field_names_ = Metadata._all_field_names_.union(FileMetadata._field_names_)
FileMetadata._fields_ = [
('id', FileMetadata._id_validator),
('client_modified', FileMetadata._client_modified_validator),
('server_modified', FileMetadata._server_modified_validator),
('rev', FileMetadata._rev_validator),
('size', FileMetadata._size_validator),
('media_info', FileMetadata._media_info_validator),
('sharing_info', FileMetadata._sharing_info_validator),
('property_groups', FileMetadata._property_groups_validator),
('has_explicit_shared_members', FileMetadata._has_explicit_shared_members_validator),
('content_hash', FileMetadata._content_hash_validator),
]
FileMetadata._all_fields_ = Metadata._all_fields_ + FileMetadata._fields_
SharingInfo._read_only_validator = bv.Boolean()
SharingInfo._all_field_names_ = set(['read_only'])
SharingInfo._all_fields_ = [('read_only', SharingInfo._read_only_validator)]
FileSharingInfo._parent_shared_folder_id_validator = common.SharedFolderId_validator
FileSharingInfo._modified_by_validator = bv.Nullable(users_common.AccountId_validator)
FileSharingInfo._all_field_names_ = SharingInfo._all_field_names_.union(set([
'parent_shared_folder_id',
'modified_by',
]))
FileSharingInfo._all_fields_ = SharingInfo._all_fields_ + [
('parent_shared_folder_id', FileSharingInfo._parent_shared_folder_id_validator),
('modified_by', FileSharingInfo._modified_by_validator),
]
FolderMetadata._id_validator = Id_validator
FolderMetadata._shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator)
FolderMetadata._sharing_info_validator = bv.Nullable(FolderSharingInfo_validator)
FolderMetadata._property_groups_validator = bv.Nullable(bv.List(file_properties.PropertyGroup_validator))
FolderMetadata._field_names_ = set([
'id',
'shared_folder_id',
'sharing_info',
'property_groups',
])
FolderMetadata._all_field_names_ = Metadata._all_field_names_.union(FolderMetadata._field_names_)
FolderMetadata._fields_ = [
('id', FolderMetadata._id_validator),
('shared_folder_id', FolderMetadata._shared_folder_id_validator),
('sharing_info', FolderMetadata._sharing_info_validator),
('property_groups', FolderMetadata._property_groups_validator),
]
FolderMetadata._all_fields_ = Metadata._all_fields_ + FolderMetadata._fields_
FolderSharingInfo._parent_shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator)
FolderSharingInfo._shared_folder_id_validator = bv.Nullable(common.SharedFolderId_validator)
FolderSharingInfo._traverse_only_validator = bv.Boolean()
FolderSharingInfo._no_access_validator = bv.Boolean()
FolderSharingInfo._all_field_names_ = SharingInfo._all_field_names_.union(set([
'parent_shared_folder_id',
'shared_folder_id',
'traverse_only',
'no_access',
]))
FolderSharingInfo._all_fields_ = SharingInfo._all_fields_ + [
('parent_shared_folder_id', FolderSharingInfo._parent_shared_folder_id_validator),
('shared_folder_id', FolderSharingInfo._shared_folder_id_validator),
('traverse_only', FolderSharingInfo._traverse_only_validator),
('no_access', FolderSharingInfo._no_access_validator),
]
GetCopyReferenceArg._path_validator = ReadPath_validator
GetCopyReferenceArg._all_field_names_ = set(['path'])
GetCopyReferenceArg._all_fields_ = [('path', GetCopyReferenceArg._path_validator)]
GetCopyReferenceError._path_validator = LookupError_validator
GetCopyReferenceError._other_validator = bv.Void()
GetCopyReferenceError._tagmap = {
'path': GetCopyReferenceError._path_validator,
'other': GetCopyReferenceError._other_validator,
}
GetCopyReferenceError.other = GetCopyReferenceError('other')
GetCopyReferenceResult._metadata_validator = Metadata_validator
GetCopyReferenceResult._copy_reference_validator = bv.String()
GetCopyReferenceResult._expires_validator = common.DropboxTimestamp_validator
GetCopyReferenceResult._all_field_names_ = set([
'metadata',
'copy_reference',
'expires',
])
GetCopyReferenceResult._all_fields_ = [
('metadata', GetCopyReferenceResult._metadata_validator),
('copy_reference', GetCopyReferenceResult._copy_reference_validator),
('expires', GetCopyReferenceResult._expires_validator),
]
GetTemporaryLinkArg._path_validator = ReadPath_validator
GetTemporaryLinkArg._all_field_names_ = set(['path'])
GetTemporaryLinkArg._all_fields_ = [('path', GetTemporaryLinkArg._path_validator)]
GetTemporaryLinkError._path_validator = LookupError_validator
GetTemporaryLinkError._other_validator = bv.Void()
GetTemporaryLinkError._tagmap = {
'path': GetTemporaryLinkError._path_validator,
'other': GetTemporaryLinkError._other_validator,
}
GetTemporaryLinkError.other = GetTemporaryLinkError('other')
GetTemporaryLinkResult._metadata_validator = FileMetadata_validator
GetTemporaryLinkResult._link_validator = bv.String()
GetTemporaryLinkResult._all_field_names_ = set([
'metadata',
'link',
])
GetTemporaryLinkResult._all_fields_ = [
('metadata', GetTemporaryLinkResult._metadata_validator),
('link', GetTemporaryLinkResult._link_validator),
]
GetThumbnailBatchArg._entries_validator = bv.List(ThumbnailArg_validator)
GetThumbnailBatchArg._all_field_names_ = set(['entries'])
GetThumbnailBatchArg._all_fields_ = [('entries', GetThumbnailBatchArg._entries_validator)]
GetThumbnailBatchError._too_many_files_validator = bv.Void()
GetThumbnailBatchError._other_validator = bv.Void()
GetThumbnailBatchError._tagmap = {
'too_many_files': GetThumbnailBatchError._too_many_files_validator,
'other': GetThumbnailBatchError._other_validator,
}
GetThumbnailBatchError.too_many_files = GetThumbnailBatchError('too_many_files')
GetThumbnailBatchError.other = GetThumbnailBatchError('other')
GetThumbnailBatchResult._entries_validator = bv.List(GetThumbnailBatchResultEntry_validator)
GetThumbnailBatchResult._all_field_names_ = set(['entries'])
GetThumbnailBatchResult._all_fields_ = [('entries', GetThumbnailBatchResult._entries_validator)]
GetThumbnailBatchResultData._metadata_validator = FileMetadata_validator
GetThumbnailBatchResultData._thumbnail_validator = bv.String()
GetThumbnailBatchResultData._all_field_names_ = set([
'metadata',
'thumbnail',
])
GetThumbnailBatchResultData._all_fields_ = [
('metadata', GetThumbnailBatchResultData._metadata_validator),
('thumbnail', GetThumbnailBatchResultData._thumbnail_validator),
]
GetThumbnailBatchResultEntry._success_validator = GetThumbnailBatchResultData_validator
GetThumbnailBatchResultEntry._failure_validator = ThumbnailError_validator
GetThumbnailBatchResultEntry._other_validator = bv.Void()
GetThumbnailBatchResultEntry._tagmap = {
'success': GetThumbnailBatchResultEntry._success_validator,
'failure': GetThumbnailBatchResultEntry._failure_validator,
'other': GetThumbnailBatchResultEntry._other_validator,
}
GetThumbnailBatchResultEntry.other = GetThumbnailBatchResultEntry('other')
GpsCoordinates._latitude_validator = bv.Float64()
GpsCoordinates._longitude_validator = bv.Float64()
GpsCoordinates._all_field_names_ = set([
'latitude',
'longitude',
])
GpsCoordinates._all_fields_ = [
('latitude', GpsCoordinates._latitude_validator),
('longitude', GpsCoordinates._longitude_validator),
]
ListFolderArg._path_validator = PathROrId_validator
ListFolderArg._recursive_validator = bv.Boolean()
ListFolderArg._include_media_info_validator = bv.Boolean()
ListFolderArg._include_deleted_validator = bv.Boolean()
ListFolderArg._include_has_explicit_shared_members_validator = bv.Boolean()
ListFolderArg._include_mounted_folders_validator = bv.Boolean()
ListFolderArg._limit_validator = bv.Nullable(bv.UInt32(min_value=1, max_value=2000))
ListFolderArg._shared_link_validator = bv.Nullable(SharedLink_validator)
ListFolderArg._all_field_names_ = set([
'path',
'recursive',
'include_media_info',
'include_deleted',
'include_has_explicit_shared_members',
'include_mounted_folders',
'limit',
'shared_link',
])
ListFolderArg._all_fields_ = [
('path', ListFolderArg._path_validator),
('recursive', ListFolderArg._recursive_validator),
('include_media_info', ListFolderArg._include_media_info_validator),
('include_deleted', ListFolderArg._include_deleted_validator),
('include_has_explicit_shared_members', ListFolderArg._include_has_explicit_shared_members_validator),
('include_mounted_folders', ListFolderArg._include_mounted_folders_validator),
('limit', ListFolderArg._limit_validator),
('shared_link', ListFolderArg._shared_link_validator),
]
ListFolderContinueArg._cursor_validator = ListFolderCursor_validator
ListFolderContinueArg._all_field_names_ = set(['cursor'])
ListFolderContinueArg._all_fields_ = [('cursor', ListFolderContinueArg._cursor_validator)]
ListFolderContinueError._path_validator = LookupError_validator
ListFolderContinueError._reset_validator = bv.Void()
ListFolderContinueError._other_validator = bv.Void()
ListFolderContinueError._tagmap = {
'path': ListFolderContinueError._path_validator,
'reset': ListFolderContinueError._reset_validator,
'other': ListFolderContinueError._other_validator,
}
ListFolderContinueError.reset = ListFolderContinueError('reset')
ListFolderContinueError.other = ListFolderContinueError('other')
ListFolderError._path_validator = LookupError_validator
ListFolderError._other_validator = bv.Void()
ListFolderError._tagmap = {
'path': ListFolderError._path_validator,
'other': ListFolderError._other_validator,
}
ListFolderError.other = ListFolderError('other')
ListFolderGetLatestCursorResult._cursor_validator = ListFolderCursor_validator
ListFolderGetLatestCursorResult._all_field_names_ = set(['cursor'])
ListFolderGetLatestCursorResult._all_fields_ = [('cursor', ListFolderGetLatestCursorResult._cursor_validator)]
ListFolderLongpollArg._cursor_validator = ListFolderCursor_validator
ListFolderLongpollArg._timeout_validator = bv.UInt64(min_value=30, max_value=480)
ListFolderLongpollArg._all_field_names_ = set([
'cursor',
'timeout',
])
ListFolderLongpollArg._all_fields_ = [
('cursor', ListFolderLongpollArg._cursor_validator),
('timeout', ListFolderLongpollArg._timeout_validator),
]
ListFolderLongpollError._reset_validator = bv.Void()
ListFolderLongpollError._other_validator = bv.Void()
ListFolderLongpollError._tagmap = {
'reset': ListFolderLongpollError._reset_validator,
'other': ListFolderLongpollError._other_validator,
}
ListFolderLongpollError.reset = ListFolderLongpollError('reset')
ListFolderLongpollError.other = ListFolderLongpollError('other')
ListFolderLongpollResult._changes_validator = bv.Boolean()
ListFolderLongpollResult._backoff_validator = bv.Nullable(bv.UInt64())
ListFolderLongpollResult._all_field_names_ = set([
'changes',
'backoff',
])
ListFolderLongpollResult._all_fields_ = [
('changes', ListFolderLongpollResult._changes_validator),
('backoff', ListFolderLongpollResult._backoff_validator),
]
ListFolderResult._entries_validator = bv.List(Metadata_validator)
ListFolderResult._cursor_validator = ListFolderCursor_validator
ListFolderResult._has_more_validator = bv.Boolean()
ListFolderResult._all_field_names_ = set([
'entries',
'cursor',
'has_more',
])
ListFolderResult._all_fields_ = [
('entries', ListFolderResult._entries_validator),
('cursor', ListFolderResult._cursor_validator),
('has_more', ListFolderResult._has_more_validator),
]
ListRevisionsArg._path_validator = PathOrId_validator
ListRevisionsArg._mode_validator = ListRevisionsMode_validator
ListRevisionsArg._limit_validator = bv.UInt64(min_value=1, max_value=100)
ListRevisionsArg._all_field_names_ = set([
'path',
'mode',
'limit',
])
ListRevisionsArg._all_fields_ = [
('path', ListRevisionsArg._path_validator),
('mode', ListRevisionsArg._mode_validator),
('limit', ListRevisionsArg._limit_validator),
]
ListRevisionsError._path_validator = LookupError_validator
ListRevisionsError._other_validator = bv.Void()
ListRevisionsError._tagmap = {
'path': ListRevisionsError._path_validator,
'other': ListRevisionsError._other_validator,
}
ListRevisionsError.other = ListRevisionsError('other')
ListRevisionsMode._path_validator = bv.Void()
ListRevisionsMode._id_validator = bv.Void()
ListRevisionsMode._other_validator = bv.Void()
ListRevisionsMode._tagmap = {
'path': ListRevisionsMode._path_validator,
'id': ListRevisionsMode._id_validator,
'other': ListRevisionsMode._other_validator,
}
ListRevisionsMode.path = ListRevisionsMode('path')
ListRevisionsMode.id = ListRevisionsMode('id')
ListRevisionsMode.other = ListRevisionsMode('other')
ListRevisionsResult._is_deleted_validator = bv.Boolean()
ListRevisionsResult._server_deleted_validator = bv.Nullable(common.DropboxTimestamp_validator)
ListRevisionsResult._entries_validator = bv.List(FileMetadata_validator)
ListRevisionsResult._all_field_names_ = set([
'is_deleted',
'server_deleted',
'entries',
])
ListRevisionsResult._all_fields_ = [
('is_deleted', ListRevisionsResult._is_deleted_validator),
('server_deleted', ListRevisionsResult._server_deleted_validator),
('entries', ListRevisionsResult._entries_validator),
]
LookupError._malformed_path_validator = MalformedPathError_validator
LookupError._not_found_validator = bv.Void()
LookupError._not_file_validator = bv.Void()
LookupError._not_folder_validator = bv.Void()
LookupError._restricted_content_validator = bv.Void()
LookupError._other_validator = bv.Void()
LookupError._tagmap = {
'malformed_path': LookupError._malformed_path_validator,
'not_found': LookupError._not_found_validator,
'not_file': LookupError._not_file_validator,
'not_folder': LookupError._not_folder_validator,
'restricted_content': LookupError._restricted_content_validator,
'other': LookupError._other_validator,
}
LookupError.not_found = LookupError('not_found')
LookupError.not_file = LookupError('not_file')
LookupError.not_folder = LookupError('not_folder')
LookupError.restricted_content = LookupError('restricted_content')
LookupError.other = LookupError('other')
MediaInfo._pending_validator = bv.Void()
MediaInfo._metadata_validator = MediaMetadata_validator
MediaInfo._tagmap = {
'pending': MediaInfo._pending_validator,
'metadata': MediaInfo._metadata_validator,
}
MediaInfo.pending = MediaInfo('pending')
MediaMetadata._dimensions_validator = bv.Nullable(Dimensions_validator)
MediaMetadata._location_validator = bv.Nullable(GpsCoordinates_validator)
MediaMetadata._time_taken_validator = bv.Nullable(common.DropboxTimestamp_validator)
MediaMetadata._field_names_ = set([
'dimensions',
'location',
'time_taken',
])
MediaMetadata._all_field_names_ = MediaMetadata._field_names_
MediaMetadata._fields_ = [
('dimensions', MediaMetadata._dimensions_validator),
('location', MediaMetadata._location_validator),
('time_taken', MediaMetadata._time_taken_validator),
]
MediaMetadata._all_fields_ = MediaMetadata._fields_
MediaMetadata._tag_to_subtype_ = {
(u'photo',): PhotoMetadata_validator,
(u'video',): VideoMetadata_validator,
}
MediaMetadata._pytype_to_tag_and_subtype_ = {
PhotoMetadata: ((u'photo',), PhotoMetadata_validator),
VideoMetadata: ((u'video',), VideoMetadata_validator),
}
MediaMetadata._is_catch_all_ = False
PhotoMetadata._field_names_ = set([])
PhotoMetadata._all_field_names_ = MediaMetadata._all_field_names_.union(PhotoMetadata._field_names_)
PhotoMetadata._fields_ = []
PhotoMetadata._all_fields_ = MediaMetadata._all_fields_ + PhotoMetadata._fields_
PreviewArg._path_validator = ReadPath_validator
PreviewArg._rev_validator = bv.Nullable(Rev_validator)
PreviewArg._all_field_names_ = set([
'path',
'rev',
])
PreviewArg._all_fields_ = [
('path', PreviewArg._path_validator),
('rev', PreviewArg._rev_validator),
]
PreviewError._path_validator = LookupError_validator
PreviewError._in_progress_validator = bv.Void()
PreviewError._unsupported_extension_validator = bv.Void()
PreviewError._unsupported_content_validator = bv.Void()
PreviewError._tagmap = {
'path': PreviewError._path_validator,
'in_progress': PreviewError._in_progress_validator,
'unsupported_extension': PreviewError._unsupported_extension_validator,
'unsupported_content': PreviewError._unsupported_content_validator,
}
PreviewError.in_progress = PreviewError('in_progress')
PreviewError.unsupported_extension = PreviewError('unsupported_extension')
PreviewError.unsupported_content = PreviewError('unsupported_content')
RelocationPath._from_path_validator = WritePathOrId_validator
RelocationPath._to_path_validator = WritePathOrId_validator
RelocationPath._all_field_names_ = set([
'from_path',
'to_path',
])
RelocationPath._all_fields_ = [
('from_path', RelocationPath._from_path_validator),
('to_path', RelocationPath._to_path_validator),
]
RelocationArg._allow_shared_folder_validator = bv.Boolean()
RelocationArg._autorename_validator = bv.Boolean()
RelocationArg._allow_ownership_transfer_validator = bv.Boolean()
RelocationArg._all_field_names_ = RelocationPath._all_field_names_.union(set([
'allow_shared_folder',
'autorename',
'allow_ownership_transfer',
]))
RelocationArg._all_fields_ = RelocationPath._all_fields_ + [
('allow_shared_folder', RelocationArg._allow_shared_folder_validator),
('autorename', RelocationArg._autorename_validator),
('allow_ownership_transfer', RelocationArg._allow_ownership_transfer_validator),
]
RelocationBatchArg._entries_validator = bv.List(RelocationPath_validator)
RelocationBatchArg._allow_shared_folder_validator = bv.Boolean()
RelocationBatchArg._autorename_validator = bv.Boolean()
RelocationBatchArg._allow_ownership_transfer_validator = bv.Boolean()
RelocationBatchArg._all_field_names_ = set([
'entries',
'allow_shared_folder',
'autorename',
'allow_ownership_transfer',
])
RelocationBatchArg._all_fields_ = [
('entries', RelocationBatchArg._entries_validator),
('allow_shared_folder', RelocationBatchArg._allow_shared_folder_validator),
('autorename', RelocationBatchArg._autorename_validator),
('allow_ownership_transfer', RelocationBatchArg._allow_ownership_transfer_validator),
]
RelocationError._from_lookup_validator = LookupError_validator
RelocationError._from_write_validator = WriteError_validator
RelocationError._to_validator = WriteError_validator
RelocationError._cant_copy_shared_folder_validator = bv.Void()
RelocationError._cant_nest_shared_folder_validator = bv.Void()
RelocationError._cant_move_folder_into_itself_validator = bv.Void()
RelocationError._too_many_files_validator = bv.Void()
RelocationError._duplicated_or_nested_paths_validator = bv.Void()
RelocationError._cant_transfer_ownership_validator = bv.Void()
RelocationError._other_validator = bv.Void()
RelocationError._tagmap = {
'from_lookup': RelocationError._from_lookup_validator,
'from_write': RelocationError._from_write_validator,
'to': RelocationError._to_validator,
'cant_copy_shared_folder': RelocationError._cant_copy_shared_folder_validator,
'cant_nest_shared_folder': RelocationError._cant_nest_shared_folder_validator,
'cant_move_folder_into_itself': RelocationError._cant_move_folder_into_itself_validator,
'too_many_files': RelocationError._too_many_files_validator,
'duplicated_or_nested_paths': RelocationError._duplicated_or_nested_paths_validator,
'cant_transfer_ownership': RelocationError._cant_transfer_ownership_validator,
'other': RelocationError._other_validator,
}
RelocationError.cant_copy_shared_folder = RelocationError('cant_copy_shared_folder')
RelocationError.cant_nest_shared_folder = RelocationError('cant_nest_shared_folder')
RelocationError.cant_move_folder_into_itself = RelocationError('cant_move_folder_into_itself')
RelocationError.too_many_files = RelocationError('too_many_files')
RelocationError.duplicated_or_nested_paths = RelocationError('duplicated_or_nested_paths')
RelocationError.cant_transfer_ownership = RelocationError('cant_transfer_ownership')
RelocationError.other = RelocationError('other')
RelocationBatchError._too_many_write_operations_validator = bv.Void()
RelocationBatchError._tagmap = {
'too_many_write_operations': RelocationBatchError._too_many_write_operations_validator,
}
RelocationBatchError._tagmap.update(RelocationError._tagmap)
RelocationBatchError.too_many_write_operations = RelocationBatchError('too_many_write_operations')
RelocationBatchJobStatus._complete_validator = RelocationBatchResult_validator
RelocationBatchJobStatus._failed_validator = RelocationBatchError_validator
RelocationBatchJobStatus._tagmap = {
'complete': RelocationBatchJobStatus._complete_validator,
'failed': RelocationBatchJobStatus._failed_validator,
}
RelocationBatchJobStatus._tagmap.update(async.PollResultBase._tagmap)
RelocationBatchLaunch._complete_validator = RelocationBatchResult_validator
RelocationBatchLaunch._other_validator = bv.Void()
RelocationBatchLaunch._tagmap = {
'complete': RelocationBatchLaunch._complete_validator,
'other': RelocationBatchLaunch._other_validator,
}
RelocationBatchLaunch._tagmap.update(async.LaunchResultBase._tagmap)
RelocationBatchLaunch.other = RelocationBatchLaunch('other')
RelocationBatchResult._entries_validator = bv.List(RelocationBatchResultData_validator)
RelocationBatchResult._all_field_names_ = FileOpsResult._all_field_names_.union(set(['entries']))
RelocationBatchResult._all_fields_ = FileOpsResult._all_fields_ + [('entries', RelocationBatchResult._entries_validator)]
RelocationBatchResultData._metadata_validator = Metadata_validator
RelocationBatchResultData._all_field_names_ = set(['metadata'])
RelocationBatchResultData._all_fields_ = [('metadata', RelocationBatchResultData._metadata_validator)]
RelocationResult._metadata_validator = Metadata_validator
RelocationResult._all_field_names_ = FileOpsResult._all_field_names_.union(set(['metadata']))
RelocationResult._all_fields_ = FileOpsResult._all_fields_ + [('metadata', RelocationResult._metadata_validator)]
RestoreArg._path_validator = WritePath_validator
RestoreArg._rev_validator = Rev_validator
RestoreArg._all_field_names_ = set([
'path',
'rev',
])
RestoreArg._all_fields_ = [
('path', RestoreArg._path_validator),
('rev', RestoreArg._rev_validator),
]
RestoreError._path_lookup_validator = LookupError_validator
RestoreError._path_write_validator = WriteError_validator
RestoreError._invalid_revision_validator = bv.Void()
RestoreError._other_validator = bv.Void()
RestoreError._tagmap = {
'path_lookup': RestoreError._path_lookup_validator,
'path_write': RestoreError._path_write_validator,
'invalid_revision': RestoreError._invalid_revision_validator,
'other': RestoreError._other_validator,
}
RestoreError.invalid_revision = RestoreError('invalid_revision')
RestoreError.other = RestoreError('other')
SaveCopyReferenceArg._copy_reference_validator = bv.String()
SaveCopyReferenceArg._path_validator = Path_validator
SaveCopyReferenceArg._all_field_names_ = set([
'copy_reference',
'path',
])
SaveCopyReferenceArg._all_fields_ = [
('copy_reference', SaveCopyReferenceArg._copy_reference_validator),
('path', SaveCopyReferenceArg._path_validator),
]
SaveCopyReferenceError._path_validator = WriteError_validator
SaveCopyReferenceError._invalid_copy_reference_validator = bv.Void()
SaveCopyReferenceError._no_permission_validator = bv.Void()
SaveCopyReferenceError._not_found_validator = bv.Void()
SaveCopyReferenceError._too_many_files_validator = bv.Void()
SaveCopyReferenceError._other_validator = bv.Void()
SaveCopyReferenceError._tagmap = {
'path': SaveCopyReferenceError._path_validator,
'invalid_copy_reference': SaveCopyReferenceError._invalid_copy_reference_validator,
'no_permission': SaveCopyReferenceError._no_permission_validator,
'not_found': SaveCopyReferenceError._not_found_validator,
'too_many_files': SaveCopyReferenceError._too_many_files_validator,
'other': SaveCopyReferenceError._other_validator,
}
SaveCopyReferenceError.invalid_copy_reference = SaveCopyReferenceError('invalid_copy_reference')
SaveCopyReferenceError.no_permission = SaveCopyReferenceError('no_permission')
SaveCopyReferenceError.not_found = SaveCopyReferenceError('not_found')
SaveCopyReferenceError.too_many_files = SaveCopyReferenceError('too_many_files')
SaveCopyReferenceError.other = SaveCopyReferenceError('other')
SaveCopyReferenceResult._metadata_validator = Metadata_validator
SaveCopyReferenceResult._all_field_names_ = set(['metadata'])
SaveCopyReferenceResult._all_fields_ = [('metadata', SaveCopyReferenceResult._metadata_validator)]
SaveUrlArg._path_validator = Path_validator
SaveUrlArg._url_validator = bv.String()
SaveUrlArg._all_field_names_ = set([
'path',
'url',
])
SaveUrlArg._all_fields_ = [
('path', SaveUrlArg._path_validator),
('url', SaveUrlArg._url_validator),
]
SaveUrlError._path_validator = WriteError_validator
SaveUrlError._download_failed_validator = bv.Void()
SaveUrlError._invalid_url_validator = bv.Void()
SaveUrlError._not_found_validator = bv.Void()
SaveUrlError._other_validator = bv.Void()
SaveUrlError._tagmap = {
'path': SaveUrlError._path_validator,
'download_failed': SaveUrlError._download_failed_validator,
'invalid_url': SaveUrlError._invalid_url_validator,
'not_found': SaveUrlError._not_found_validator,
'other': SaveUrlError._other_validator,
}
SaveUrlError.download_failed = SaveUrlError('download_failed')
SaveUrlError.invalid_url = SaveUrlError('invalid_url')
SaveUrlError.not_found = SaveUrlError('not_found')
SaveUrlError.other = SaveUrlError('other')
SaveUrlJobStatus._complete_validator = FileMetadata_validator
SaveUrlJobStatus._failed_validator = SaveUrlError_validator
SaveUrlJobStatus._tagmap = {
'complete': SaveUrlJobStatus._complete_validator,
'failed': SaveUrlJobStatus._failed_validator,
}
SaveUrlJobStatus._tagmap.update(async.PollResultBase._tagmap)
SaveUrlResult._complete_validator = FileMetadata_validator
SaveUrlResult._tagmap = {
'complete': SaveUrlResult._complete_validator,
}
SaveUrlResult._tagmap.update(async.LaunchResultBase._tagmap)
SearchArg._path_validator = PathROrId_validator
SearchArg._query_validator = bv.String()
SearchArg._start_validator = bv.UInt64()
SearchArg._max_results_validator = bv.UInt64(min_value=1, max_value=1000)
SearchArg._mode_validator = SearchMode_validator
SearchArg._all_field_names_ = set([
'path',
'query',
'start',
'max_results',
'mode',
])
SearchArg._all_fields_ = [
('path', SearchArg._path_validator),
('query', SearchArg._query_validator),
('start', SearchArg._start_validator),
('max_results', SearchArg._max_results_validator),
('mode', SearchArg._mode_validator),
]
SearchError._path_validator = LookupError_validator
SearchError._other_validator = bv.Void()
SearchError._tagmap = {
'path': SearchError._path_validator,
'other': SearchError._other_validator,
}
SearchError.other = SearchError('other')
SearchMatch._match_type_validator = SearchMatchType_validator
SearchMatch._metadata_validator = Metadata_validator
SearchMatch._all_field_names_ = set([
'match_type',
'metadata',
])
SearchMatch._all_fields_ = [
('match_type', SearchMatch._match_type_validator),
('metadata', SearchMatch._metadata_validator),
]
SearchMatchType._filename_validator = bv.Void()
SearchMatchType._content_validator = bv.Void()
SearchMatchType._both_validator = bv.Void()
SearchMatchType._tagmap = {
'filename': SearchMatchType._filename_validator,
'content': SearchMatchType._content_validator,
'both': SearchMatchType._both_validator,
}
SearchMatchType.filename = SearchMatchType('filename')
SearchMatchType.content = SearchMatchType('content')
SearchMatchType.both = SearchMatchType('both')
SearchMode._filename_validator = bv.Void()
SearchMode._filename_and_content_validator = bv.Void()
SearchMode._deleted_filename_validator = bv.Void()
SearchMode._tagmap = {
'filename': SearchMode._filename_validator,
'filename_and_content': SearchMode._filename_and_content_validator,
'deleted_filename': SearchMode._deleted_filename_validator,
}
SearchMode.filename = SearchMode('filename')
SearchMode.filename_and_content = SearchMode('filename_and_content')
SearchMode.deleted_filename = SearchMode('deleted_filename')
SearchResult._matches_validator = bv.List(SearchMatch_validator)
SearchResult._more_validator = bv.Boolean()
SearchResult._start_validator = bv.UInt64()
SearchResult._all_field_names_ = set([
'matches',
'more',
'start',
])
SearchResult._all_fields_ = [
('matches', SearchResult._matches_validator),
('more', SearchResult._more_validator),
('start', SearchResult._start_validator),
]
SharedLink._url_validator = SharedLinkUrl_validator
SharedLink._password_validator = bv.Nullable(bv.String())
SharedLink._all_field_names_ = set([
'url',
'password',
])
SharedLink._all_fields_ = [
('url', SharedLink._url_validator),
('password', SharedLink._password_validator),
]
ThumbnailArg._path_validator = ReadPath_validator
ThumbnailArg._format_validator = ThumbnailFormat_validator
ThumbnailArg._size_validator = ThumbnailSize_validator
ThumbnailArg._all_field_names_ = set([
'path',
'format',
'size',
])
ThumbnailArg._all_fields_ = [
('path', ThumbnailArg._path_validator),
('format', ThumbnailArg._format_validator),
('size', ThumbnailArg._size_validator),
]
ThumbnailError._path_validator = LookupError_validator
ThumbnailError._unsupported_extension_validator = bv.Void()
ThumbnailError._unsupported_image_validator = bv.Void()
ThumbnailError._conversion_error_validator = bv.Void()
ThumbnailError._tagmap = {
'path': ThumbnailError._path_validator,
'unsupported_extension': ThumbnailError._unsupported_extension_validator,
'unsupported_image': ThumbnailError._unsupported_image_validator,
'conversion_error': ThumbnailError._conversion_error_validator,
}
ThumbnailError.unsupported_extension = ThumbnailError('unsupported_extension')
ThumbnailError.unsupported_image = ThumbnailError('unsupported_image')
ThumbnailError.conversion_error = ThumbnailError('conversion_error')
ThumbnailFormat._jpeg_validator = bv.Void()
ThumbnailFormat._png_validator = bv.Void()
ThumbnailFormat._tagmap = {
'jpeg': ThumbnailFormat._jpeg_validator,
'png': ThumbnailFormat._png_validator,
}
ThumbnailFormat.jpeg = ThumbnailFormat('jpeg')
ThumbnailFormat.png = ThumbnailFormat('png')
ThumbnailSize._w32h32_validator = bv.Void()
ThumbnailSize._w64h64_validator = bv.Void()
ThumbnailSize._w128h128_validator = bv.Void()
ThumbnailSize._w640h480_validator = bv.Void()
ThumbnailSize._w1024h768_validator = bv.Void()
ThumbnailSize._tagmap = {
'w32h32': ThumbnailSize._w32h32_validator,
'w64h64': ThumbnailSize._w64h64_validator,
'w128h128': ThumbnailSize._w128h128_validator,
'w640h480': ThumbnailSize._w640h480_validator,
'w1024h768': ThumbnailSize._w1024h768_validator,
}
ThumbnailSize.w32h32 = ThumbnailSize('w32h32')
ThumbnailSize.w64h64 = ThumbnailSize('w64h64')
ThumbnailSize.w128h128 = ThumbnailSize('w128h128')
ThumbnailSize.w640h480 = ThumbnailSize('w640h480')
ThumbnailSize.w1024h768 = ThumbnailSize('w1024h768')
UploadError._path_validator = UploadWriteFailed_validator
UploadError._other_validator = bv.Void()
UploadError._tagmap = {
'path': UploadError._path_validator,
'other': UploadError._other_validator,
}
UploadError.other = UploadError('other')
UploadErrorWithProperties._properties_error_validator = file_properties.InvalidPropertyGroupError_validator
UploadErrorWithProperties._tagmap = {
'properties_error': UploadErrorWithProperties._properties_error_validator,
}
UploadErrorWithProperties._tagmap.update(UploadError._tagmap)
UploadSessionAppendArg._cursor_validator = UploadSessionCursor_validator
UploadSessionAppendArg._close_validator = bv.Boolean()
UploadSessionAppendArg._all_field_names_ = set([
'cursor',
'close',
])
UploadSessionAppendArg._all_fields_ = [
('cursor', UploadSessionAppendArg._cursor_validator),
('close', UploadSessionAppendArg._close_validator),
]
UploadSessionCursor._session_id_validator = bv.String()
UploadSessionCursor._offset_validator = bv.UInt64()
UploadSessionCursor._all_field_names_ = set([
'session_id',
'offset',
])
UploadSessionCursor._all_fields_ = [
('session_id', UploadSessionCursor._session_id_validator),
('offset', UploadSessionCursor._offset_validator),
]
UploadSessionFinishArg._cursor_validator = UploadSessionCursor_validator
UploadSessionFinishArg._commit_validator = CommitInfo_validator
UploadSessionFinishArg._all_field_names_ = set([
'cursor',
'commit',
])
UploadSessionFinishArg._all_fields_ = [
('cursor', UploadSessionFinishArg._cursor_validator),
('commit', UploadSessionFinishArg._commit_validator),
]
UploadSessionFinishBatchArg._entries_validator = bv.List(UploadSessionFinishArg_validator, max_items=1000)
UploadSessionFinishBatchArg._all_field_names_ = set(['entries'])
UploadSessionFinishBatchArg._all_fields_ = [('entries', UploadSessionFinishBatchArg._entries_validator)]
UploadSessionFinishBatchJobStatus._complete_validator = UploadSessionFinishBatchResult_validator
UploadSessionFinishBatchJobStatus._tagmap = {
'complete': UploadSessionFinishBatchJobStatus._complete_validator,
}
UploadSessionFinishBatchJobStatus._tagmap.update(async.PollResultBase._tagmap)
UploadSessionFinishBatchLaunch._complete_validator = UploadSessionFinishBatchResult_validator
UploadSessionFinishBatchLaunch._other_validator = bv.Void()
UploadSessionFinishBatchLaunch._tagmap = {
'complete': UploadSessionFinishBatchLaunch._complete_validator,
'other': UploadSessionFinishBatchLaunch._other_validator,
}
UploadSessionFinishBatchLaunch._tagmap.update(async.LaunchResultBase._tagmap)
UploadSessionFinishBatchLaunch.other = UploadSessionFinishBatchLaunch('other')
UploadSessionFinishBatchResult._entries_validator = bv.List(UploadSessionFinishBatchResultEntry_validator)
UploadSessionFinishBatchResult._all_field_names_ = set(['entries'])
UploadSessionFinishBatchResult._all_fields_ = [('entries', UploadSessionFinishBatchResult._entries_validator)]
UploadSessionFinishBatchResultEntry._success_validator = FileMetadata_validator
UploadSessionFinishBatchResultEntry._failure_validator = UploadSessionFinishError_validator
UploadSessionFinishBatchResultEntry._tagmap = {
'success': UploadSessionFinishBatchResultEntry._success_validator,
'failure': UploadSessionFinishBatchResultEntry._failure_validator,
}
UploadSessionFinishError._lookup_failed_validator = UploadSessionLookupError_validator
UploadSessionFinishError._path_validator = WriteError_validator
UploadSessionFinishError._too_many_shared_folder_targets_validator = bv.Void()
UploadSessionFinishError._too_many_write_operations_validator = bv.Void()
UploadSessionFinishError._other_validator = bv.Void()
UploadSessionFinishError._tagmap = {
'lookup_failed': UploadSessionFinishError._lookup_failed_validator,
'path': UploadSessionFinishError._path_validator,
'too_many_shared_folder_targets': UploadSessionFinishError._too_many_shared_folder_targets_validator,
'too_many_write_operations': UploadSessionFinishError._too_many_write_operations_validator,
'other': UploadSessionFinishError._other_validator,
}
UploadSessionFinishError.too_many_shared_folder_targets = UploadSessionFinishError('too_many_shared_folder_targets')
UploadSessionFinishError.too_many_write_operations = UploadSessionFinishError('too_many_write_operations')
UploadSessionFinishError.other = UploadSessionFinishError('other')
UploadSessionLookupError._not_found_validator = bv.Void()
UploadSessionLookupError._incorrect_offset_validator = UploadSessionOffsetError_validator
UploadSessionLookupError._closed_validator = bv.Void()
UploadSessionLookupError._not_closed_validator = bv.Void()
UploadSessionLookupError._other_validator = bv.Void()
UploadSessionLookupError._tagmap = {
'not_found': UploadSessionLookupError._not_found_validator,
'incorrect_offset': UploadSessionLookupError._incorrect_offset_validator,
'closed': UploadSessionLookupError._closed_validator,
'not_closed': UploadSessionLookupError._not_closed_validator,
'other': UploadSessionLookupError._other_validator,
}
UploadSessionLookupError.not_found = UploadSessionLookupError('not_found')
UploadSessionLookupError.closed = UploadSessionLookupError('closed')
UploadSessionLookupError.not_closed = UploadSessionLookupError('not_closed')
UploadSessionLookupError.other = UploadSessionLookupError('other')
UploadSessionOffsetError._correct_offset_validator = bv.UInt64()
UploadSessionOffsetError._all_field_names_ = set(['correct_offset'])
UploadSessionOffsetError._all_fields_ = [('correct_offset', UploadSessionOffsetError._correct_offset_validator)]
UploadSessionStartArg._close_validator = bv.Boolean()
UploadSessionStartArg._all_field_names_ = set(['close'])
UploadSessionStartArg._all_fields_ = [('close', UploadSessionStartArg._close_validator)]
UploadSessionStartResult._session_id_validator = bv.String()
UploadSessionStartResult._all_field_names_ = set(['session_id'])
UploadSessionStartResult._all_fields_ = [('session_id', UploadSessionStartResult._session_id_validator)]
UploadWriteFailed._reason_validator = WriteError_validator
UploadWriteFailed._upload_session_id_validator = bv.String()
UploadWriteFailed._all_field_names_ = set([
'reason',
'upload_session_id',
])
UploadWriteFailed._all_fields_ = [
('reason', UploadWriteFailed._reason_validator),
('upload_session_id', UploadWriteFailed._upload_session_id_validator),
]
VideoMetadata._duration_validator = bv.Nullable(bv.UInt64())
VideoMetadata._field_names_ = set(['duration'])
VideoMetadata._all_field_names_ = MediaMetadata._all_field_names_.union(VideoMetadata._field_names_)
VideoMetadata._fields_ = [('duration', VideoMetadata._duration_validator)]
VideoMetadata._all_fields_ = MediaMetadata._all_fields_ + VideoMetadata._fields_
WriteConflictError._file_validator = bv.Void()
WriteConflictError._folder_validator = bv.Void()
WriteConflictError._file_ancestor_validator = bv.Void()
WriteConflictError._other_validator = bv.Void()
WriteConflictError._tagmap = {
'file': WriteConflictError._file_validator,
'folder': WriteConflictError._folder_validator,
'file_ancestor': WriteConflictError._file_ancestor_validator,
'other': WriteConflictError._other_validator,
}
WriteConflictError.file = WriteConflictError('file')
WriteConflictError.folder = WriteConflictError('folder')
WriteConflictError.file_ancestor = WriteConflictError('file_ancestor')
WriteConflictError.other = WriteConflictError('other')
WriteError._malformed_path_validator = MalformedPathError_validator
WriteError._conflict_validator = WriteConflictError_validator
WriteError._no_write_permission_validator = bv.Void()
WriteError._insufficient_space_validator = bv.Void()
WriteError._disallowed_name_validator = bv.Void()
WriteError._team_folder_validator = bv.Void()
WriteError._other_validator = bv.Void()
WriteError._tagmap = {
'malformed_path': WriteError._malformed_path_validator,
'conflict': WriteError._conflict_validator,
'no_write_permission': WriteError._no_write_permission_validator,
'insufficient_space': WriteError._insufficient_space_validator,
'disallowed_name': WriteError._disallowed_name_validator,
'team_folder': WriteError._team_folder_validator,
'other': WriteError._other_validator,
}
WriteError.no_write_permission = WriteError('no_write_permission')
WriteError.insufficient_space = WriteError('insufficient_space')
WriteError.disallowed_name = WriteError('disallowed_name')
WriteError.team_folder = WriteError('team_folder')
WriteError.other = WriteError('other')
WriteMode._add_validator = bv.Void()
WriteMode._overwrite_validator = bv.Void()
WriteMode._update_validator = Rev_validator
WriteMode._tagmap = {
'add': WriteMode._add_validator,
'overwrite': WriteMode._overwrite_validator,
'update': WriteMode._update_validator,
}
WriteMode.add = WriteMode('add')
WriteMode.overwrite = WriteMode('overwrite')
alpha_get_metadata = bb.Route(
'alpha/get_metadata',
False,
AlphaGetMetadataArg_validator,
Metadata_validator,
AlphaGetMetadataError_validator,
{'host': u'api',
'style': u'rpc'},
)
alpha_upload = bb.Route(
'alpha/upload',
False,
CommitInfoWithProperties_validator,
FileMetadata_validator,
UploadErrorWithProperties_validator,
{'host': u'content',
'style': u'upload'},
)
copy = bb.Route(
'copy',
True,
RelocationArg_validator,
Metadata_validator,
RelocationError_validator,
{'host': u'api',
'style': u'rpc'},
)
copy_batch = bb.Route(
'copy_batch',
False,
RelocationBatchArg_validator,
RelocationBatchLaunch_validator,
bv.Void(),
{'host': u'api',
'style': u'rpc'},
)
copy_batch_check = bb.Route(
'copy_batch/check',
False,
async.PollArg_validator,
RelocationBatchJobStatus_validator,
async.PollError_validator,
{'host': u'api',
'style': u'rpc'},
)
copy_reference_get = bb.Route(
'copy_reference/get',
False,
GetCopyReferenceArg_validator,
GetCopyReferenceResult_validator,
GetCopyReferenceError_validator,
{'host': u'api',
'style': u'rpc'},
)
copy_reference_save = bb.Route(
'copy_reference/save',
False,
SaveCopyReferenceArg_validator,
SaveCopyReferenceResult_validator,
SaveCopyReferenceError_validator,
{'host': u'api',
'style': u'rpc'},
)
copy_v2 = bb.Route(
'copy_v2',
False,
RelocationArg_validator,
RelocationResult_validator,
RelocationError_validator,
{'host': u'api',
'style': u'rpc'},
)
create_folder = bb.Route(
'create_folder',
True,
CreateFolderArg_validator,
FolderMetadata_validator,
CreateFolderError_validator,
{'host': u'api',
'style': u'rpc'},
)
create_folder_v2 = bb.Route(
'create_folder_v2',
False,
CreateFolderArg_validator,
CreateFolderResult_validator,
CreateFolderError_validator,
{'host': u'api',
'style': u'rpc'},
)
delete = bb.Route(
'delete',
True,
DeleteArg_validator,
Metadata_validator,
DeleteError_validator,
{'host': u'api',
'style': u'rpc'},
)
delete_batch = bb.Route(
'delete_batch',
False,
DeleteBatchArg_validator,
DeleteBatchLaunch_validator,
bv.Void(),
{'host': u'api',
'style': u'rpc'},
)
delete_batch_check = bb.Route(
'delete_batch/check',
False,
async.PollArg_validator,
DeleteBatchJobStatus_validator,
async.PollError_validator,
{'host': u'api',
'style': u'rpc'},
)
delete_v2 = bb.Route(
'delete_v2',
False,
DeleteArg_validator,
DeleteResult_validator,
DeleteError_validator,
{'host': u'api',
'style': u'rpc'},
)
download = bb.Route(
'download',
False,
DownloadArg_validator,
FileMetadata_validator,
DownloadError_validator,
{'host': u'content',
'style': u'download'},
)
get_metadata = bb.Route(
'get_metadata',
False,
GetMetadataArg_validator,
Metadata_validator,
GetMetadataError_validator,
{'host': u'api',
'style': u'rpc'},
)
get_preview = bb.Route(
'get_preview',
False,
PreviewArg_validator,
FileMetadata_validator,
PreviewError_validator,
{'host': u'content',
'style': u'download'},
)
get_temporary_link = bb.Route(
'get_temporary_link',
False,
GetTemporaryLinkArg_validator,
GetTemporaryLinkResult_validator,
GetTemporaryLinkError_validator,
{'host': u'api',
'style': u'rpc'},
)
get_thumbnail = bb.Route(
'get_thumbnail',
False,
ThumbnailArg_validator,
FileMetadata_validator,
ThumbnailError_validator,
{'host': u'content',
'style': u'download'},
)
get_thumbnail_batch = bb.Route(
'get_thumbnail_batch',
False,
GetThumbnailBatchArg_validator,
GetThumbnailBatchResult_validator,
GetThumbnailBatchError_validator,
{'host': u'content',
'style': u'rpc'},
)
list_folder = bb.Route(
'list_folder',
False,
ListFolderArg_validator,
ListFolderResult_validator,
ListFolderError_validator,
{'host': u'api',
'style': u'rpc'},
)
list_folder_continue = bb.Route(
'list_folder/continue',
False,
ListFolderContinueArg_validator,
ListFolderResult_validator,
ListFolderContinueError_validator,
{'host': u'api',
'style': u'rpc'},
)
list_folder_get_latest_cursor = bb.Route(
'list_folder/get_latest_cursor',
False,
ListFolderArg_validator,
ListFolderGetLatestCursorResult_validator,
ListFolderError_validator,
{'host': u'api',
'style': u'rpc'},
)
list_folder_longpoll = bb.Route(
'list_folder/longpoll',
False,
ListFolderLongpollArg_validator,
ListFolderLongpollResult_validator,
ListFolderLongpollError_validator,
{'host': u'notify',
'style': u'rpc'},
)
list_revisions = bb.Route(
'list_revisions',
False,
ListRevisionsArg_validator,
ListRevisionsResult_validator,
ListRevisionsError_validator,
{'host': u'api',
'style': u'rpc'},
)
move = bb.Route(
'move',
True,
RelocationArg_validator,
Metadata_validator,
RelocationError_validator,
{'host': u'api',
'style': u'rpc'},
)
move_batch = bb.Route(
'move_batch',
False,
RelocationBatchArg_validator,
RelocationBatchLaunch_validator,
bv.Void(),
{'host': u'api',
'style': u'rpc'},
)
move_batch_check = bb.Route(
'move_batch/check',
False,
async.PollArg_validator,
RelocationBatchJobStatus_validator,
async.PollError_validator,
{'host': u'api',
'style': u'rpc'},
)
move_v2 = bb.Route(
'move_v2',
False,
RelocationArg_validator,
RelocationResult_validator,
RelocationError_validator,
{'host': u'api',
'style': u'rpc'},
)
permanently_delete = bb.Route(
'permanently_delete',
False,
DeleteArg_validator,
bv.Void(),
DeleteError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_add = bb.Route(
'properties/add',
True,
file_properties.AddPropertiesArg_validator,
bv.Void(),
file_properties.AddPropertiesError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_overwrite = bb.Route(
'properties/overwrite',
True,
file_properties.OverwritePropertyGroupArg_validator,
bv.Void(),
file_properties.InvalidPropertyGroupError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_remove = bb.Route(
'properties/remove',
True,
file_properties.RemovePropertiesArg_validator,
bv.Void(),
file_properties.RemovePropertiesError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_template_get = bb.Route(
'properties/template/get',
True,
file_properties.GetTemplateArg_validator,
file_properties.GetTemplateResult_validator,
file_properties.TemplateError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_template_list = bb.Route(
'properties/template/list',
True,
bv.Void(),
file_properties.ListTemplateResult_validator,
file_properties.TemplateError_validator,
{'host': u'api',
'style': u'rpc'},
)
properties_update = bb.Route(
'properties/update',
True,
file_properties.UpdatePropertiesArg_validator,
bv.Void(),
file_properties.UpdatePropertiesError_validator,
{'host': u'api',
'style': u'rpc'},
)
restore = bb.Route(
'restore',
False,
RestoreArg_validator,
FileMetadata_validator,
RestoreError_validator,
{'host': u'api',
'style': u'rpc'},
)
save_url = bb.Route(
'save_url',
False,
SaveUrlArg_validator,
SaveUrlResult_validator,
SaveUrlError_validator,
{'host': u'api',
'style': u'rpc'},
)
save_url_check_job_status = bb.Route(
'save_url/check_job_status',
False,
async.PollArg_validator,
SaveUrlJobStatus_validator,
async.PollError_validator,
{'host': u'api',
'style': u'rpc'},
)
search = bb.Route(
'search',
False,
SearchArg_validator,
SearchResult_validator,
SearchError_validator,
{'host': u'api',
'style': u'rpc'},
)
upload = bb.Route(
'upload',
False,
CommitInfo_validator,
FileMetadata_validator,
UploadError_validator,
{'host': u'content',
'style': u'upload'},
)
upload_session_append = bb.Route(
'upload_session/append',
True,
UploadSessionCursor_validator,
bv.Void(),
UploadSessionLookupError_validator,
{'host': u'content',
'style': u'upload'},
)
upload_session_append_v2 = bb.Route(
'upload_session/append_v2',
False,
UploadSessionAppendArg_validator,
bv.Void(),
UploadSessionLookupError_validator,
{'host': u'content',
'style': u'upload'},
)
upload_session_finish = bb.Route(
'upload_session/finish',
False,
UploadSessionFinishArg_validator,
FileMetadata_validator,
UploadSessionFinishError_validator,
{'host': u'content',
'style': u'upload'},
)
upload_session_finish_batch = bb.Route(
'upload_session/finish_batch',
False,
UploadSessionFinishBatchArg_validator,
UploadSessionFinishBatchLaunch_validator,
bv.Void(),
{'host': u'api',
'style': u'rpc'},
)
upload_session_finish_batch_check = bb.Route(
'upload_session/finish_batch/check',
False,
async.PollArg_validator,
UploadSessionFinishBatchJobStatus_validator,
async.PollError_validator,
{'host': u'api',
'style': u'rpc'},
)
upload_session_start = bb.Route(
'upload_session/start',
False,
UploadSessionStartArg_validator,
UploadSessionStartResult_validator,
bv.Void(),
{'host': u'content',
'style': u'upload'},
)
ROUTES = {
'alpha/get_metadata': alpha_get_metadata,
'alpha/upload': alpha_upload,
'copy': copy,
'copy_batch': copy_batch,
'copy_batch/check': copy_batch_check,
'copy_reference/get': copy_reference_get,
'copy_reference/save': copy_reference_save,
'copy_v2': copy_v2,
'create_folder': create_folder,
'create_folder_v2': create_folder_v2,
'delete': delete,
'delete_batch': delete_batch,
'delete_batch/check': delete_batch_check,
'delete_v2': delete_v2,
'download': download,
'get_metadata': get_metadata,
'get_preview': get_preview,
'get_temporary_link': get_temporary_link,
'get_thumbnail': get_thumbnail,
'get_thumbnail_batch': get_thumbnail_batch,
'list_folder': list_folder,
'list_folder/continue': list_folder_continue,
'list_folder/get_latest_cursor': list_folder_get_latest_cursor,
'list_folder/longpoll': list_folder_longpoll,
'list_revisions': list_revisions,
'move': move,
'move_batch': move_batch,
'move_batch/check': move_batch_check,
'move_v2': move_v2,
'permanently_delete': permanently_delete,
'properties/add': properties_add,
'properties/overwrite': properties_overwrite,
'properties/remove': properties_remove,
'properties/template/get': properties_template_get,
'properties/template/list': properties_template_list,
'properties/update': properties_update,
'restore': restore,
'save_url': save_url,
'save_url/check_job_status': save_url_check_job_status,
'search': search,
'upload': upload,
'upload_session/append': upload_session_append,
'upload_session/append_v2': upload_session_append_v2,
'upload_session/finish': upload_session_finish,
'upload_session/finish_batch': upload_session_finish_batch,
'upload_session/finish_batch/check': upload_session_finish_batch_check,
'upload_session/start': upload_session_start,
}