Source code for b2sdk.sync.file

######################################################################
#
# File: b2sdk/sync/file.py
#
# Copyright 2019 Backblaze Inc. All Rights Reserved.
#
# License https://www.backblaze.com/using_b2_code.html
#
######################################################################


[docs]class File(object): """ Hold information about one file in a folder. The name is relative to the folder in all cases. Files that have multiple versions (which only happens in B2, not in local folders) include information about all of the versions, most recent first. """ __slots__ = ['name', 'versions']
[docs] def __init__(self, name, versions): """ :param name: a relative file name :type name: str :param versions: a list of file versions :type versions: list """ self.name = name self.versions = versions
[docs] def latest_version(self): """ Return the latest file version. """ return self.versions[0]
def __repr__(self): return 'File(%s, [%s])' % (self.name, ', '.join(repr(v) for v in self.versions))
[docs]class FileVersion(object): """ Hold information about one version of a file. """ __slots__ = ['id_', 'name', 'mod_time', 'action', 'size']
[docs] def __init__(self, id_, file_name, mod_time, action, size): """ :param id_: the B2 file id, or the local full path name :type id_: str :param file_name: a relative file name :type file_name: str :param mod_time: modification time, in milliseconds, to avoid rounding issues with millisecond times from B2 :type mod_time: int :param action: "hide" or "upload" (never "start") :type action: str :param size: a file size :type size: int """ self.id_ = id_ self.name = file_name self.mod_time = mod_time self.action = action self.size = size
def __repr__(self): return 'FileVersion(%s, %s, %s, %s)' % ( repr(self.id_), repr(self.name), repr(self.mod_time), repr(self.action) )