snapm package¶
Module contents¶
Snapm top-level package.
-
class
snapm.FsTabReader(path='/etc/fstab')[source]¶ Bases:
objectA class to read and query data from an fstab file.
This class reads an fstab-like file and provides methods to iterate over its entries and look up specific entries based on their properties.
-
class
FsTabEntry(what, where, fstype, options, freq, passno)¶ Bases:
tuple-
__repr__()¶ Return a nicely formatted representation string
-
freq¶ Alias for field number 4
-
fstype¶ Alias for field number 2
-
options¶ Alias for field number 3
-
passno¶ Alias for field number 5
-
what¶ Alias for field number 0
-
where¶ Alias for field number 1
-
-
__init__(path='/etc/fstab')[source]¶ Initializes the FsTabReader object by reading and parsing the file.
- Parameters
path (str) – The path to the fstab file. Defaults to ‘/etc/fstab’.
- Raises
SnapmNotFoundError – If the specified fstab file does not exist.
SnapmSystemError – If there is an error reading the fstab file.
-
lookup(key, value)[source]¶ Finds and generates all entries matching a specific key-value pair.
- Parameters
key (str) – The field to search by. Must be one of ‘what’, ‘where’, ‘fstype’, ‘options’, ‘freq’, or ‘passno’.
value (str|int) – The value to match for the given key.
- Yields
A 6-tuple for each matching fstab entry.
- Raises
KeyError – If the provided key is not a valid fstab field name.
-
class
-
class
snapm.ProgressAwareHandler(stream: Optional[TextIO] = None, **kwargs)[source]¶ Bases:
logging.StreamHandlerA logging handler that coordinates with active Progress instances.
After emitting a log record, notifies any Progress instances writing to the same stream so they can avoid erasing the log message.
-
__init__(stream: Optional[TextIO] = None, **kwargs)[source]¶ Initialize the handler.
If stream is not specified, sys.stderr is used.
-
emit(record)[source]¶ Emit a record.
If a formatter is specified, it is used to format the record. The record is then written to the stream with a trailing newline. If exception information is present, it is formatted using traceback.print_exception and appended to the stream. If the stream has an ‘encoding’ attribute, it is used to determine how to do the output to the stream.
-
-
class
snapm.Selection(name=None, uuid=None, basename=None, index=None, timestamp=None, nr_snapshots=None, mount_points=None, origin=None, mount_point=None, snapshot_name=None, snapshot_uuid=None, sched_name: Union[None, str] = None, sched_sources: Union[None, str] = None, sched_default_size_policy: Union[None, str] = None, sched_autoindex: Union[None, bool] = None, sched_gc_type: Union[None, str] = None, sched_gc_params: Union[None, str] = None, sched_enabled: Union[None, bool] = None, sched_running: Union[None, bool] = None, sched_calendarspec: Union[None, str] = None)[source]¶ Bases:
objectSelection criteria for snapshot sets and snapshots.
-
__init__(name=None, uuid=None, basename=None, index=None, timestamp=None, nr_snapshots=None, mount_points=None, origin=None, mount_point=None, snapshot_name=None, snapshot_uuid=None, sched_name: Union[None, str] = None, sched_sources: Union[None, str] = None, sched_default_size_policy: Union[None, str] = None, sched_autoindex: Union[None, bool] = None, sched_gc_type: Union[None, str] = None, sched_gc_params: Union[None, str] = None, sched_enabled: Union[None, bool] = None, sched_running: Union[None, bool] = None, sched_calendarspec: Union[None, str] = None)[source]¶ Initialize self. See help(type(self)) for accurate signature.
-
__repr__()[source]¶ Format this
Selectionobject as a machine readable string.The returned string may be passed to the Selection initialiser to duplicate the original Selection.
- Returns
A machine readable string representation of this Selection object
- Return type
string
-
__str__()[source]¶ Format this
Selectionobject as a human readable string.- Returns
A human readable string representation of this Selection object
- Return type
string
-
all_attrs= ['name', 'uuid', 'basename', 'index', 'timestamp', 'nr_snapshots', 'mount_points', 'origin', 'mount_point', 'snapshot_name', 'snapshot_uuid', 'sched_name', 'sched_sources', 'sched_default_size_policy', 'sched_autoindex', 'sched_gc_type', 'sched_gc_params', 'sched_enabled', 'sched_running', 'sched_calendarspec']¶
-
basename= None¶
-
check_valid_selection(snapshot_set=False, snapshot=False, schedule=False)[source]¶ Check a Selection for valid criteria.
Check this
Selectionobject to ensure it contains only criteria that are valid for the specified object type(s).Returns
Noneif the object passes the check, or raiseValueErrorif invalid criteria exist.- Parameters
snapshot_set –
Selectionmay include SnapshotSet datasnapshot –
Selectionmay include Snapshot data
- Returns
Noneon success- Return type
NoneType- Raises
ValueErrorif excluded criteria are present
-
classmethod
from_cmd_args(cmd_args)[source]¶ Initialise Selection from command line arguments.
Construct a new
Selectionobject from the command line arguments incmd_args. Each set selection attribute fromcmd_argsis copied into the Selection. The resulting object may be passed to either theSnapshotSetorSnapshotsearch functions. (find_snapshot_sets,find_snapshots, as well as thesnapm.commandcalls that accept a selection argument.- Parameters
cmd_args – The command line selection arguments.
- Returns
A new Selection instance
- Return type
-
index= None¶
-
is_null()[source]¶ Test this Selection object for null selection criteria.
Return
Trueif thisSelectionobject matches all objects, orFalseotherwise.- Returns
Trueif this Selection is null- Return type
bool
-
is_single()[source]¶ Test this Selection object for single item selection criteria.
Returns
Trueif thisSelectionobject matches a single object orFalseotherwise.A
Selectionobject matches a single object if either thenameoruuidfields is specified.- Returns
Trueif this selection is single orFalseotherwise.- Return type
bool
-
mount_point= None¶
-
mount_points= None¶
-
name= None¶
-
nr_snapshots= None¶
-
origin= None¶
-
sched_autoindex: Union[None, bool] = None¶
-
sched_calendarspec: Union[None, str] = None¶
-
sched_default_size_policy: Union[None, str] = None¶
-
sched_enabled: Union[None, bool] = None¶
-
sched_gc_params: Union[None, str] = None¶
-
sched_gc_type: Union[None, str] = None¶
-
sched_name: Union[None, str] = None¶
-
sched_running: Union[None, bool] = None¶
-
sched_sources: Union[None, str] = None¶
-
schedule_attrs= ['sched_name', 'sched_sources', 'sched_default_size_policy', 'sched_autoindex', 'sched_gc_type', 'sched_gc_params', 'sched_enabled', 'sched_running', 'sched_calendarspec']¶
-
snapshot_attrs= ['origin', 'mount_point', 'snapshot_name', 'snapshot_uuid']¶
-
snapshot_name= None¶
-
snapshot_set_attrs= ['name', 'uuid', 'basename', 'index', 'timestamp', 'nr_snapshots', 'mount_points']¶
-
snapshot_uuid= None¶
-
timestamp= None¶
-
uuid= None¶
-
-
class
snapm.SizePolicy(source, mount, free_space, fs_used, dev_size, policy)[source]¶ Bases:
objectClass representing a configured instance of a size policy.
-
__init__(source, mount, free_space, fs_used, dev_size, policy)[source]¶ Initialise a new SizePolicy object using the supplied parameters.
- Parameters
source – The source for this SizePolicy: a mount point or block device path.
mount – The mount point path if mounted.
free_space – The free space available to provision the snapshot in bytes.
fs_used – The current file system occupancy in bytes.
dev_size – The origin device size in bytes.
policy – A size policy string.
- Returns
A SizePolicy object configured for the specified size.
-
property
size¶ Return the backing store size for a snapshot based on the policy configuration.
-
-
class
snapm.SizePolicyType(value)[source]¶ Bases:
enum.EnumEnum class representing the possible snapshot size policies.
-
FIXED= 'FIXED'¶
-
PERCENT_FREE= 'FREE'¶
-
PERCENT_SIZE= 'SIZE'¶
-
PERCENT_USED= 'USED'¶
-
-
class
snapm.SnapStatus(value)[source]¶ Bases:
enum.EnumEnum class representing snapshot status: Active, Inactive, Invalid or Reverting.
-
ACTIVE= 1¶
-
INACTIVE= 2¶
-
INVALID= 3¶
-
REVERTING= 4¶
-
-
exception
snapm.SnapmArgumentError[source]¶ Bases:
snapm._snapm.SnapmErrorAn invalid argument was passed to a snapshot manager API call.
-
exception
snapm.SnapmBusyError[source]¶ Bases:
snapm._snapm.SnapmErrorA resource needed by the current command is already in use: for e.g. a snapshot merge is in progress for a previous snapshot set.
-
exception
snapm.SnapmCalloutError[source]¶ Bases:
snapm._snapm.SnapmErrorAn error calling out to an external program.
-
exception
snapm.SnapmExistsError[source]¶ Bases:
snapm._snapm.SnapmErrorThe named snapshot set already exists.
-
exception
snapm.SnapmInvalidIdentifierError[source]¶ Bases:
snapm._snapm.SnapmErrorAn invalid identifier was given.
-
exception
snapm.SnapmLimitError[source]¶ Bases:
snapm._snapm.SnapmErrorA configured resource limit would be exceeded.
-
exception
snapm.SnapmMountError(what: str, where: str, status: int, stderr: str)[source]¶ Bases:
snapm._snapm.SnapmErrorAn error performing a mount operation.
-
__init__(what: str, where: str, status: int, stderr: str)[source]¶ Initialise a new SnapmMountError exception.
- Parameters
what – The source for the failed mount operation.
where – The intended mount point of the operation.
status – The exit status of the mount(8) program.
stderr – The error message from mount(8).
-
-
exception
snapm.SnapmNoProviderError[source]¶ Bases:
snapm._snapm.SnapmErrorNo snapshot provider plugin was found.
-
exception
snapm.SnapmNoSpaceError[source]¶ Bases:
snapm._snapm.SnapmErrorInsufficient space is available for the requested operation.
-
exception
snapm.SnapmNotFoundError[source]¶ Bases:
snapm._snapm.SnapmErrorThe requested object does not exist.
-
exception
snapm.SnapmParseError[source]¶ Bases:
snapm._snapm.SnapmErrorAn error parsing user input.
-
exception
snapm.SnapmPathError[source]¶ Bases:
snapm._snapm.SnapmErrorAn invalid path was supplied, for example attempting to snapshot something that is not a mount point or block device.
-
exception
snapm.SnapmPluginError[source]¶ Bases:
snapm._snapm.SnapmErrorAn error performing an action via a plugin.
-
exception
snapm.SnapmRecursionError[source]¶ Bases:
snapm._snapm.SnapmErrorA snapshot set source corresponds to a snapshot of another snapshot set.
-
exception
snapm.SnapmSizePolicyError[source]¶ Bases:
snapm._snapm.SnapmErrorAn invalid size policy was specified.
-
exception
snapm.SnapmStateError[source]¶ Bases:
snapm._snapm.SnapmErrorThe status of an object does not allow an operation to proceed.
-
exception
snapm.SnapmSystemError[source]¶ Bases:
snapm._snapm.SnapmErrorAn error when calling the operating system.
-
exception
snapm.SnapmTimerError[source]¶ Bases:
snapm._snapm.SnapmErrorAn error manipulating systemd timers.
-
exception
snapm.SnapmUmountError(where: str, status: int, stderr: str)[source]¶ Bases:
snapm._snapm.SnapmErrorAn error performing an unmount operation.
-
class
snapm.Snapshot(name, snapset_name, origin, timestamp, mount_point, provider)[source]¶ Bases:
abc.ABCAbstract base class for individual snapshots. Each snapshot plugin should subclass
Snapshotto provide a specific implementation.-
__init__(name, snapset_name, origin, timestamp, mount_point, provider)[source]¶ Initialise a new
Snapshotobject.- Parameters
name – The name of the snapshot.
snapset_name – The name of the
SnapshotSetthis snapshot is a part of.origin – The origin volume of the snapshot.
timestamp – The creation timestamp of the snapshot set.
mount_point – The mount point path this snapshot refers to.
provider – The plugin providing this snapshot.
-
__str__()[source]¶ Return a string representation of this
Snapshotobject.- Returns
A multi-line string describing this snapshot.
-
as_dict()¶ Return a representation of this
Snapshotas a dictionary.
-
abstract property
autoactivate¶ The autoactivation status of this snapshot. Returns
Trueif the snapshot is automatically activated orFalseotherwise.
-
check_resize(size_policy)[source]¶ Check whether this snapshot can be resized or not by calling the provider plugin with the updated
size_policy.
-
check_revert()[source]¶ Check whether this snapshot can be reverted or not by calling the provider plugin to verify the state of the snapshot.
-
abstract property
devpath¶ The device path for this snapshot.
-
abstract property
free¶ The space available to this snapshot in bytes. For snapshots with fixed-size backstores this reflects the space remaining in the current backstore. For snapshots that dynamically allocate space to the snapshot it indicates the pooled space available.
-
property
index¶ The index of this snapshot, if set, or the special value
snapm.SNAPSHOT_INDEX_NONEotherwise.
-
property
mount_point¶ The mount point of this snapshot.
-
property
mounted¶ Test whether either the snapshot or origin volume for this
Snapshotis currently mounted and in use.- Returns
Trueif this snapshot or its origin is currently mounted orFalseotherwise.
-
property
name¶ The name of this snapshot.
-
abstract property
origin¶ The origin of this snapshot.
-
property
origin_mounted¶ Test whether the origin volume for this
Snapshotis currently mounted and in use.- Returns
Trueif this snapshot’s origin is currently mounted orFalseotherwise.
-
abstract property
origin_options¶ File system options needed to specify the origin of this snapshot.
-
rename(new_name)[source]¶ Rename a snapshot within a snapshot set.
- Parameters
new_name – The new name for the snapshot.
-
revert()[source]¶ Request to revert a snapshot and revert the content of the origin volume to its state at the time of the snapshot.
This may be deferred until the next device activation or mount operation for the respective volume.
-
abstract property
size¶ The size of this snapshot in bytes. For snapshots with fixed-size backstores this reflects the size of the backstore. For snapshots that dynamically allocate space to the snapshot it reflects the device or volume size.
-
property
snapset_basename¶ The basename of the snapshot set this snapshot belongs to, minus any index.
-
property
snapset_name¶ The name of the snapshot set this snapshot belongs to.
-
property
snapshot_mounted¶ Test whether the snapshot volume for this
Snapshotis currently mounted and in use.- Returns
Trueif this snapshot is currently mounted orFalseotherwise.
-
property
snapshot_set¶ The
SnapshotSetthis snapshot belongs to.
-
property
source¶ The block device or mount point from which this
Snapshotwas created.
-
abstract property
status¶ The status of this snapshot. Returns a
SnapStatusenum value representing the current state of the snapshot.
-
property
time¶ The human readable timestamp of this snapshot.
-
property
timestamp¶ The numerical timestamp of this snapshot.
-
property
uuid¶ The UUID of this snapshot.
-
-
class
snapm.SnapshotSet(name, timestamp, snapshots)[source]¶ Bases:
objectRepresentation of a set of snapshots taken at the same point in time and managed as a group.
-
__init__(name, timestamp, snapshots)[source]¶ Initialise a new
SnapshotSetobject.- Parameters
name – The name of this
SnapshotSet.timestamp – The creation timestamp of this
SnapshotSet.snapshots – A list of
Snapshotobjects to be included in this set.
-
__str__()[source]¶ Return a string representation of this
SnapshotSet.- Returns
A multi-line string describing this snapshot set.
-
activate()[source]¶ Attempt to activate all members of this
SnapshotSet.- Raises
SnapmPluginErrorif a plugin fails to perform the requested operation.
-
as_dict(members=False)¶ Backwards compatibility
-
property
autoactivate¶ The overall autoactivation status of this snapshot set. Returns
Trueif all snapshots within the set have autoactivate enabled orFalseotherwise.
-
property
basename¶ The basename of this snapshot set, minus any index.
-
property
categories¶ Return the time categories to which this
SnapshotSetbelongs as a list of strings.- Returns
A list of human readable time category strings.
- Return type
List[str]
-
property
datetime¶ The timestamp of this snapshot set as a
datetime.datetimeobject.
-
deactivate()[source]¶ Attempt to deactivate all members of this
SnapshotSet.- Raises
SnapmPluginErrorif a plugin fails to perform the requested operation.
-
delete()[source]¶ Delete the on-disk representation of this
SnapshotSet.- Raises
SnapmBusyErrorif the snapshot set is in use.SnapmPluginErrorif an error occurs deleting snapshot set members.
-
property
devices¶ The list of block devices in this snapshot set.
-
property
index¶ The index of this snapshot set, if set, or the special value
snapm.SNAPSET_INDEX_NONEotherwise.
-
json(members=False, pretty=False)[source]¶ Return a string representation of this
SnapshotSetin JSON notation.
-
property
mount_points¶ The list of mount points in this snapshot set.
-
property
mounted¶ Test whether the either the origin or snapshot volumes for this
SnapshotSetare currently mounted and in use.- Returns
Trueif any of the snapshots belonging to thisSnapshotSetare currently mounted, orFalseotherwise.
-
property
name¶ The name of this snapshot set.
-
property
nr_snapshots¶ The number of snapshots in this snapshot set.
-
property
origin_mounted¶ Test whether the origin volumes for this
SnapshotSetare currently mounted and in use.- Returns
Trueif any of the snapshots belonging to thisSnapshotSetare currently mounted, orFalseotherwise.
-
rename(new_name)[source]¶ Rename this
SnapshotSettonew_name.- Raises
SnapmErrorif a call to rename any member of the snapshot set fails.
-
resize(sources, size_policies)[source]¶ Attempt to resize the
SnapshotSetaccording to the list ofsourcesand correspondingsize_policystrings.- Raises
SnapmNoSpaceErrorif there is insufficient space available for the requested operation.
-
revert()[source]¶ Initiate a revert operation on this
SnapshotSet.- Raises
SnapmPluginErrorif a plugin fails to perform the requested operation.
-
set_categories(categories: List[str])[source]¶ Set the time categories to which this
SnapshotSetbelongs as a list of strings. This should only be called by theManagerclass after running snapshot set recategorization: it is not intended to be called from client code.- Parameters
categories (
List[str]) – The list of categories to set for thisSnapshotSet.
-
snapshot_by_mount_point(mount_point)[source]¶ Return the snapshot corresponding to
mount_point.- Parameters
mount_point – The mount point path to search for.
- Returns
A
Snapshotobject for the given mount point.- Raises
SnapmNotFoundErrorif the specified mount point is not present in thisSnapshotSet.
-
snapshot_by_source(source)[source]¶ Return the snapshot corresponding to
source.- Parameters
source – The block device or mount point path to search for.
- Returns
A
Snapshotobject for the given source path.- Raises
SnapmNotFoundErrorif the specified source path is not present in thisSnapshotSet.
-
property
snapshot_mounted¶ Test whether the snapshot volumes for this
SnapshotSetare currently mounted and in use.- Returns
Trueif any of the snapshots belonging to thisSnapshotSetare currently mounted, orFalseotherwise.
-
property
snapshots¶ The list of snapshots in this snapshot set.
-
property
sources¶ The list of source mount points and block devices in this snapshot set.
-
property
status¶ The overall status of this snapshot set. Returns
SnapStatus.ACTIVEif all members of the set are valid and active,SnapStatus.INACTIVEif any members are inactive, orSnapStatus.INVALIDif any member of the set is invalid.
-
property
time¶ The human readable timestamp of this snapshot set.
-
property
timestamp¶ The numerical timestamp of this snapshot set.
-
property
uuid¶ The UUID of this snapshot set.
-
-
class
snapm.SubsystemFilter(name='')[source]¶ Bases:
logging.FilterFilters DEBUG records based on a set of enabled subsystem names. Non-DEBUG records or DEBUG records without a ‘subsystem’ attribute are always passed through.
-
__init__(name='')[source]¶ Initialize a filter.
Initialize with the name of the logger which, together with its children, will have its events allowed through the filter. If no name is specified, allow every event.
-
-
snapm.bool_to_yes_no(value)[source]¶ Convert boolean-like to yes/no string.
Return the string “yes” if
valueevaluates toTrue, or “no” otherwise.- Parameters
value – A boolean value to interpret.
- Returns
A string value that is “yes” if
valueisTrue, or “no” otherwise.
-
snapm.build_snapset_mount_list(snapset: snapm._snapm.SnapshotSet, fstab: snapm._snapm.FsTabReader)[source]¶ Build a list of command line mount unit definitions for the snapshot set
snapset. Mount points that are not part of the snapset are substituted from /etc/fstab.- Parameters
snapset (SnapshotSet) – The snapshot set to build a mount list for.
fstab (FsTabReader) – An
FsTabReaderinstance to use.
- Returns
A list of 4-tuples, each containing (device_path, mount_point, filesystem_type, mount_options) for auxiliary mounts. The root filesystem (“/”) and swap entries are excluded from the list.
- Return type
List[Tuple[str, str, str, str]]
-
snapm.find_snapset_root(snapset, fstab: snapm._snapm.FsTabReader, origin: bool = False)[source]¶ Find the device that backs the root filesystem for snapshot set
snapset.If the snapset does not include the root volume look the device up via the fstab.
- Parameters
snapset (SnapshotSet) – The
SnapshotSetto check.fstab (FsTabReader) – An
FsTabReaderinstance to use.origin (bool) – Always return the origin device, even if a snapshot exists for the root mount point.
- Returns
The device path for the root filesystem.
- Return type
str
- Raises
SnapmNotFoundError – If no root device can be found in the snapshot set or fstab.
-
snapm.get_current_rss() → int[source]¶ Return the running process’s current VmRSS value in bytes.
- Returns
VmRSS read from /proc/self/status as an integer byte value, or 0 meaning “VmRSS unavailable”.
- Type
int
-
snapm.get_debug_mask()[source]¶ Return the current debug mask for the
snapmpackage.- Returns
The current debug mask value
- Return type
int
-
snapm.get_device_fstype(devpath: str) → str[source]¶ Determine the file system type for the device at devpath.
- Parameters
devpath – The path to the device.
- Returns
The file system type, ‘xfs’, ‘ext4’, ‘swap’, etc.
- Return type
str
- Raises
SnapmNotFoundError – If the device is not found.
SnapmSystemError – If the ‘blkid’ command exits with a non-zero status due to reasons other than the identifier not being found (e.g., permission issues).
SnapmCalloutError – For any other unexpected errors during command execution or parsing.
-
snapm.get_device_path(by_type: str, identifier: str) → Optional[str][source]¶ Translates a filesystem UUID or label to its corresponding device path using the blkid command.
- Parameters
by_type – The type of identifier to search for.
identifier – The UUID or label of the filesystem.
- Returns
The device path if found, otherwise None.
- Return type
Optional[str]
- Raises
ValueError – If ‘identifier’ is empty or ‘by_type’ is not ‘uuid’ or ‘label’.
SnapmNotFoundError – If the ‘blkid’ command is not found on the system.
SnapmSystemError – If the ‘blkid’ command exits with a non-zero status due to reasons other than the identifier not being found (e.g., permission issues).
SnapmCalloutError – For any other unexpected errors during command execution or parsing.
-
snapm.get_total_memory() → int[source]¶ Return the total physical memory available to the system, excluding swap, in bytes, or 0 meaning “MemTotal” unavailable.
- Returns
Total physical RAM in bytes.
- Return type
int
-
snapm.is_size_policy(policy)[source]¶ Test whether a string is a valid size policy
- Parameters
policy – A possible policy string to test.
- Returns
Trueifpolicyis a valid size policy string orFalseotherwise.
-
snapm.notify_log_output(stream: TextIO)[source]¶ Notify progress instances that log output occurred on stream.
Called by ProgressAwareHandler after emitting a record.
- Parameters
stream (
TextIO) – The stream that received output.
-
snapm.parse_size_with_units(value)[source]¶ Parse a size string with optional unit suffix and return a value in bytes,
- Parameters
size – The size string to parse.
- Returns
an integer size in bytes.
- Raises
ValueErrorif the string could not be parsed as a valid size value.
-
snapm.register_progress(progress: Union[ProgressBase, ThrobberBase])[source]¶ Register a progress instance for log coordination.
-
snapm.select_snapshot(select, snapshot)[source]¶ Test SnapshotSet against Selection criteria.
Test the supplied
Snapshotagainst the selection criteria inselectand returnTrueif it passes, orFalseotherwise.- Parameters
select – The selection criteria
snapshot – The Snapshot to test
- Return type
bool
- Returns
True if Snapshot passes selection or
Falseotherwise.
-
snapm.select_snapshot_set(select, snapshot_set)[source]¶ Test SnapshotSet against Selection criteria.
Test the supplied
SnapshotSetagainst the selection criteria inselectand returnTrueif it passes, orFalseotherwise.- Parameters
select – The selection criteria
snapshot_set – The SnapshotSet to test
- Return type
bool
- Returns
True if SnapshotSet passes selection or
Falseotherwise.
-
snapm.set_debug_mask(mask)[source]¶ Set the debug mask for the
snapmpackage.- Parameters
mask – the logical OR of the
SNAPM_DEBUG_*values to log.- Return type
None
Submodules¶
snapm.manager module¶
Top level interface to the snapshot manager.
-
class
snapm.manager.CalendarSpec(calendarspec: str)[source]¶ Bases:
objectClass representing systemd CalendarSpec expressions.
-
__init__(calendarspec: str)[source]¶ Validate and parse a systemd calendarspec expression into a CalendarSpec object.
- Parameters
calendarspec – A string containing an calendarspec expression.
- Raises
ValueErrorifcalendarspecis not a valid calendarspec expression.
-
__repr__()[source]¶ Return a string representation of this
CalendarSpecinstance in the form of a call to the CalendarSpec initializer.
-
_cond_refresh()[source]¶ Refresh this
CalendarSpecobject’s time-dependent properties if the currentnext_elapsevalue is in the past.
-
property
from_now¶ Return a string representation of the time remaining until this
CalendarSpecnext elapses.- Returns
The time remaining until the next elapse as a string.
- Return type
str
-
property
in_utc¶ Return the next elapse time for this
CalendarSpecobject as an instance ofdatetime.datetimein UTC.- Returns
The next elapse time as a UTC
datetimeobject.- Return type
datetime.datetime
-
property
next_elapse¶ Return the next elapse time for this
CalendarSpecobject as an instance ofdatetime.datetime.- Returns
The next elapse time as a
datetimeobject.- Return type
datetime.datetime
-
property
occurs¶ Trueif thisCalendarSpecobject’s calendar expression will occur in the future, orFalseotherwise.
-
property
original¶ The original form of this
CalendarSpecas a string.
-
-
class
snapm.manager.GcPolicy(policy_name: str, policy_type: snapm.manager._schedule.GcPolicyType, params: dict)[source]¶ Bases:
objectAn instance of a garbage collection policy.
-
__init__(policy_name: str, policy_type: snapm.manager._schedule.GcPolicyType, params: dict)[source]¶ Initialise a new GcPolicy.
- Parameters
policy_type (
GcPolicyType) – The policy type.params (
dict) – A dictionary of parameters suitable forpolicy_type.
-
__repr__()[source]¶ Return a machine readable string representation of this
GcPolicy.- Returns
A machine readable string.
- Return type
str
-
__str__()[source]¶ Return a human readable string representation of this
GcPolicy.- Returns
A human readable string.
- Return type
str
-
property
enabled¶ Return
Trueif thisGcPolicyand its corresponding timer are enabled, andFalseotherwise.
-
evaluate(sets: List[snapm._snapm.SnapshotSet])[source]¶ Evaluate the list of
SnapshotSetobjects insetsagainst thisGcPolicyand return a list ofSnapshotSetobjects that should be garbage collected.- Parameters
sets (
list[SnapshotSet].) – The list ofSnapshotSetobjects to evaluate, sorted in order of increasing creation date.- Returns
A list of
SnapshotSetobjects to garbage collect.- Return type
list[SnapshotSet]
-
classmethod
from_cmd_args(cmd_args)[source]¶ Initialise garbage collection policy from command line arguments.
Construct a new
GcPolicyobject from the command line arguments incmd_args. TheGcPolicyTypeis determined by thepolicy_typeargument, and the type-specific policy parameters are initialised from the remaining arguments.- Parameters
cmd_args – The command line selection arguments.
- Returns
A new
GcPolicyinstance- Return type
GcPolicy
-
classmethod
from_dict(data)[source]¶ Instantiate a
GcPolicyobject from values indata.- Parameters
data (
dict) – A dictionary describing aGcPolicyinstance.- Returns
An instance of
GcPolicyreflecting the values indata.- Return type
GcPolicy
-
classmethod
from_json(value)[source]¶ Instantiate a
GcPolicyobject from a JSON string invalue.- Parameters
value – A JSON string describing a
GcPolicyParamsinstance.- Returns
An instance of a
GcPolicyParamssubclass reflecting the values in the JSON stringvalue.- Return type
GcPolicyParams
-
property
has_params¶ Return
Trueif thisGcPolicyobject has defined policy parameters orFalseotherwise.- Returns
Trueif parameters are set elseFalse.- Return type
bool
-
json(pretty=False)[source]¶ Return a JSON representation of this
GcPolicy.- Returns
This
GcPolicyas a JSON string.- Return type
str
-
property
name¶ This
GcPolicyinstance’s name.
-
property
params¶ This
GcPolicyinstance’sGcPolicyParamsvalue.
-
property
running¶ Return
Trueif thisGcPolicyand its corresponding timer are enabled, andFalseotherwise.
-
to_dict()[source]¶ Return a dictionary representation of this
GcPolicy.- Returns
This
GcPolicyas a dictionary.- Return type
dict
-
property
type¶ This
GcPolicyinstance’sGcPolicyTypevalue.
-
-
class
snapm.manager.GcPolicyType(value)[source]¶ Bases:
enum.EnumGarbage collection policy types enum.
-
AGE= 'Age'¶
-
ALL= 'All'¶
-
COUNT= 'Count'¶
-
TIMELINE= 'Timeline'¶
-
-
class
snapm.manager.Manager[source]¶ Bases:
objectSnapshot Manager high level interface.
-
_check_recursion(origins)[source]¶ Verify that each entry in
originscorresponds to a device that is not a snapshot belonging to another snapshot set.- Parameters
origins – A list of origin devices to check.
- Raises
SnapmRecursionErrorif an origin device is a snapshot.
-
_find_and_verify_plugins(sources, size_policies)[source]¶ Find snapshot provider plugins for each source in
sourcesand verify that a provider exists for each source present.- Parameters
sources – A list of source mount point or block device paths.
size_policies – A dictionary mapping sources to size policies.
- Returns
A dictionary mapping sources to plugins.
-
_find_next_index(basename)[source]¶ Find the next index value for the recurring snapset with basename
basename.- Parameters
basename – The basename of the recurring snapset
- Returns
An integer index value
-
_load_plugin_config(plugin_name: str) → configparser.ConfigParser[source]¶ Load optional configuration file for plugin
plugin_name.- Parameters
plugin_name (
str) – The name of the plugin to load config for.- Returns
A (possibly empty)
ConfigParserinstance.- Return type
ConfigParser
-
_recategorize_snapshot_sets()[source]¶ Update the mapping of snapshot sets to “yearly”, “monthly”, “quarterly”, etc. categories.
-
_set_autoactivate(snapset, auto=False)[source]¶ Set autoactivation for
snapset.- Parameters
snapset – The
SnapshotSetobject to operate on.auto –
Trueto enable autoactivation orFalseotherwise.
-
_snapset_from_name_or_uuid(name=None, uuid=None)[source]¶ Look a snapshot set up by
nameoruuid. Returns aSnapshotSetcorresponding to eithernameoruuid`, or raises ``SnapmErroron error.- Parameters
name – The name of the snapshot set to look up.
uuid – The UUID of the snapshot set to look up.
- Returns
A
SnapshotSetcorresponding to the given name or UUID.- Raises
SnapmNotFoundErroris the name or UUID cannot be found.SnapmInvalidIdentifierErrorif the name and UUID do not match.
-
_validate_snapset_name(name)[source]¶ Validate a snapshot set name.
Returns if
nameis a valid snapshot set name or raises an appropriate exception otherwise.- Parameters
name – The snapshot set name to validate.
- Raises
SnapmExistsErrorif the name is already in use, orSnapmInvalidIdentifierErrorif the name fails validation.
-
activate_snapshot_set(name=None, uuid=None)[source]¶ Activate snapshot set by name or uuid.
- Parameters
name – The name of the snapshot set to activate.
uuid – The UUID of the snapshot set to activate.
-
activate_snapshot_sets(selection)[source]¶ Activate snapshot sets matching selection criteria
selection.- Parameters
selection – Selection criteria for snapshot sets to activate.
-
create_snapshot_set(name, source_specs, default_size_policy=None, boot=False, revert=False, autoindex=False)[source]¶ Create a snapshot set of the supplied mount points with the name
name.- Parameters
name – The name of the snapshot set.
source_specs – A list of mount point and block device paths to include in the set.
default_size_policy – A default size policy to use for the set.
boot – Create a snapshot boot entry for this snapshot set.
revert – Create a revert boot entry for this snapshot set.
autoindex – Treat name as the basename of a recurring snapshot set and generate and append an appropriate index value.
- Raises
SnapmExistsErrorif the name is already in use, orSnapmInvalidIdentifierErrorif the name fails validation.
-
create_snapshot_set_boot_entry(name=None, uuid=None)[source]¶ Create a snapshot boot entry for the specified snapshot set.
- Parameters
name – The name of the snapshot set.
uuid – The UUID of the snapshot set.
- Raises
SnapmExistsErrorif a boot entry already exists for the snapshot set.- Raises
SnapmPluginErrorif autoactivation could not be enabled.
-
create_snapshot_set_revert_entry(name=None, uuid=None)[source]¶ Create a revert boot entry for the specified snapshot set.
- Parameters
name – The name of the snapshot set.
uuid – The UUID of the snapshot set.
-
deactivate_snapshot_set(name=None, uuid=None)[source]¶ Deactivate snapshot set by name or uuid.
- Parameters
name – The name of the snapshot set to deactivate.
uuid – The UUID of the snapshot set to deactivate.
-
deactivate_snapshot_sets(selection)[source]¶ Deactivate snapshot sets matching selection criteria
selection.- Parameters
selection – Selection criteria for snapshot sets to deactivate.
-
delete_snapshot_set(name=None, uuid=None, recategorize=True)[source]¶ Remove snapshot sets by name or UUID.
- Parameters
name (
str) – The name of the snapshot set to delete.uuid (
UUID) – The UUID of the snapshot set to delete.recategorize (
bool) – Recategorize snapshot sets after deletion.
-
delete_snapshot_sets(selection)[source]¶ Remove snapshot sets matching selection criteria
selection.- Parameters
selection – Selection criteria for snapshot sets to remove.
-
discover_snapshot_sets()[source]¶ Discover snapshot sets by calling into each plugin to find individual snapshots and then aggregating them together into snapshot sets.
Initialises the
snapshot_sets,by_nameandby_uuidmembers with the discovered snapshot sets.
-
find_snapshot_sets(selection=None)[source]¶ Find snapshot sets matching selection criteria.
- Parameters
selection – Selection criteria to apply.
- Returns
A list of matching
SnapshotSetobjects.
-
find_snapshots(selection=None)[source]¶ Find snapshots matching selection criteria.
- Parameters
selection – Selection criteria to apply.
- Returns
A list of matching
Snapshotobjects.
-
rename_snapshot_set(old_name, new_name)[source]¶ Rename snapshot set
old_nameasnew_name.- Parameters
old_name – The name of the snapshot set to be renamed.
new_name – The new name of the snapshot set.
- Raises
SnapmExistsErrorif the name is already in use, orSnapmInvalidIdentifierErrorif the name fails validation.
-
resize_snapshot_set(source_specs, name=None, uuid=None, default_size_policy=None)[source]¶ Resize snapshot set named
nameor having UUIDuuid.Request to resize each snapshot included in
source_specsaccording to the given size policy, or applydefault_size_policyif set.- Parameters
name – The name of the snapshot set to resize.
uuid – The UUID of the snapshot set to resize.
source_specs – A list of mount points and optional size policies.
default_size_policy – A default size policy to apply to the resize.
-
revert_snapshot_set(name=None, uuid=None)[source]¶ Revert snapshot set named
nameor having UUIDuuid.Request to revert each snapshot origin within each snapshot set to the state at the time the snapshot was taken.
- Parameters
name – The name of the snapshot set to revert.
uuid – The UUID of the snapshot set to revert.
-
revert_snapshot_sets(selection)[source]¶ Revert snapshot sets matching selection criteria
selection.Request to revert each snapshot origin within each snapshot set to the state at the time the snapshot was taken.
- Parameters
selection – Selection criteria for snapshot sets to revert.
-
set_autoactivate(selection, auto=False)[source]¶ Set autoactivation state for snapshot sets matching selection criteria
selection.- Parameters
selection – Selection criteria for snapshot sets to set autoactivation.
auto –
Trueto enable autoactivation orFalseotherwise.
-
split_snapshot_set(name, new_name, source_specs)[source]¶ Split the snapshot set named name into two snapshot sets, with new_name containing the listed sources and name containing all remaining snapshots.
If new_name is None the listed snapshot are removed from name and permanently deleted. This operation cannot be undone.
- Parameters
name – The name of the snapshot set to split
new_name – The name of the newly split off snapshot set
sources – The list of sources to include in the new snapshot set
-
-
class
snapm.manager.Schedule(name: str, sources: List[str], default_size_policy: Optional[str], autoindex: bool, calendarspec: str, gc_policy: snapm.manager._schedule.GcPolicy, boot=False, revert=False)[source]¶ Bases:
objectAn individual snapshot schedule instance with create and garbage collection timers. Tracks timer configuration, name, sources, size policies, enabled/disabled, nr snapshots, next elapse.
-
__init__(name: str, sources: List[str], default_size_policy: Optional[str], autoindex: bool, calendarspec: str, gc_policy: snapm.manager._schedule.GcPolicy, boot=False, revert=False)[source]¶ Initialise a new
Scheduleinstance.- Parameters
name (
str) – The name of theSchedule.sources (
list[str]) – The source specs to include in thisSchedule.default_size_policy (
str) – The default size policy for thisSchedule.autoindex (
bool) – Enable autoindex names for thisSchedule.calendarspec (
str) – TheOnCalendarexpression for thisSchedule.policy (
GcPolicy) – The garbage collection policy for thisSchedule.
- Returns
The new
Scheduleinstance.- Return type
Schedule
-
__repr__()[source]¶ Return a machine-readable representation of this
Schedule.- Returns
A machine-readable string.
- Return type
str
-
__str__()[source]¶ Return a human-readable representation of this
Schedule.- Returns
A human-readable string.
- Return type
str
-
property
autoindex¶ The autoindex property for this
Schedule.
-
property
boot¶ Return
Trueif thisScheduleis configured to enable snapshot set boot entries when creating snapshot sets.
-
property
calendarspec¶ The OnCalendar expression for the timer associated with this
Scheduleinstance.
-
property
default_size_policy¶ The default size policy for this
Schedule.
-
property
enabled¶ Return
Trueif thisScheduleand its corresponding timer are enabled, andFalseotherwise.
-
classmethod
from_dict(data)[source]¶ Instantiate a
Scheduleobject from values indata.- Parameters
data (
dict) – A dictionary describing aScheduleinstance.- Returns
An instance of
Schedulereflecting the values indata.- Return type
GcPolicyParams
-
classmethod
from_file(sched_file)[source]¶ Initialise a new
Scheduleinstance from an on-disk JSON configuration file.- Parameters
sched_file (
str) – The path to the schedule configuration file.- Returns
A new
Scheduleinstance.- Return type
Schedule
-
gc(sets: List[snapm._snapm.SnapshotSet]) → List[str][source]¶ Apply the configured garbage collection policy for this
Schedule.
-
property
gc_policy¶ The garbage collection policy for this
Schedule.
-
json(pretty=False)[source]¶ Return a JSON representation of this
Schedule.- Returns
This
Scheduleas a JSON string.- Return type
str
-
property
name¶ The name of this
Schedule.
-
property
next_elapse¶ Return the
next_elapsetime of thisSchedule’s timer.
-
property
revert¶ Return
Trueif thisScheduleis configured to enable snapshot set revert entries when creating snapshot sets.
-
property
running¶ Return
Trueif thisScheduleand its corresponding timer are enabled, andFalseotherwise.
-
property
sources¶ The source specs value for this
Schedule.
-
snapm.command module¶
The snapm.command module provides both the snapm command line
interface infrastructure, and a simple procedural interface to the
snapm library modules.
The procedural interface is used by the snapm command line tool,
and may be used by application programs, or interactively in the
Python shell by users who do not require all the features present
in the snapm object API.
-
snapm.command.PR_DIFF= 16¶ DiffRecord report object type
-
snapm.command.PR_PLUGIN= 4¶ Plugin report object type
-
snapm.command.PR_SCHEDULE= 8¶ Schedule report object type
-
snapm.command.PR_SNAPSET= 1¶ Snapshot set report object type
-
snapm.command.PR_SNAPSHOT= 2¶ Snapshot report object type
-
class
snapm.command.ReportObj(snapset=None, snapshot=None, plugin=None, schedule=None, diff=None)[source]¶ Bases:
objectCommon report object for snapm reports
-
snapm.command._activate_cmd(cmd_args)[source]¶ Activate snapshot set command handler.
Attempt to activate the snapshot sets that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._add_identifier_args(parser, snapset=False, snapshot=False)[source]¶ Add snapshot set or snapshot identifier command line arguments.
-
snapm.command._add_plugin_subparser(type_subparser)[source]¶ Add subparser for ‘plugin’ commands.
- Parameters
type_subparser – Command type subparser
-
snapm.command._add_schedule_subparser(type_subparser)[source]¶ Add subparser for ‘schedule’ commands.
- Parameters
type_subparser – Command type subparser
-
snapm.command._add_snapset_subparser(type_subparser)[source]¶ Add subparser for ‘snapset’ commands.
- Parameters
type_subparser – Command type subparser
-
snapm.command._add_snapshot_subparser(type_subparser)[source]¶ Add subparser for ‘snapshot’ commands.
- Parameters
type_subparser – Command type subparser
-
snapm.command._autoactivate_cmd(cmd_args)[source]¶ Autoactivation status snapshot set command handler.
Attempt to set the autoactivation status for snapshot set that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._create_cmd(cmd_args)[source]¶ create snapshot set command handler. attempt to create the specified snapshot set.
- Parameters
cmd_args – command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._deactivate_cmd(cmd_args)[source]¶ Deactivate snapshot set command handler.
Attempt to deactivate the snapshot sets that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._delete_cmd(cmd_args)[source]¶ Delete snapshot set command handler.
Attempt to delete the specified snapshot set.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._diff_cache_opts(cache: str, expires: Optional[int])[source]¶ Helper to set cache options for diff commands.
- Parameters
cache (
str) – Cache mode string (“auto”, “always”, “never”)expires (
Optional[int]) – Expiry value in seconds (0 to disable, -1 to use built-in defaults).
- Returns
A 2-tuple of (cache_enabled: bool, expires: int).
- Return type
(bool, int)
-
snapm.command._diff_cmd(cmd_args)[source]¶ Diff snapshot set command handler.
Compare between snapshot sets or the running system.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._diffreport_cmd(cmd_args)[source]¶ Diff Report snapshot set command handler.
Compare between snapshot sets or the running system.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._do_print_type(report_fields, selected, output_fields=None, opts=None, sort_keys=None, title=None)[source]¶ Print an object type report (snapshot set, snapshot)
Helper for list function that generate reports.
Format a set of snapshot set or snapshot objects matching the given criteria and format them as a report, returning the output as a string.
Selection criteria may be expressed via a Selection object passed to the call using the
selectionparameter.- Parameters
selection – A Selection object giving selection criteria for the operation
output_fields – a comma-separated list of output fields
opts – output formatting and control options
sort_keys – a comma-separated list of sort keys
- Return type
str
-
snapm.command._exec_cmd(cmd_args)[source]¶ Execute in snapshot set command handler.
Execute the specified command in the given snapshot set.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._expand_fields(default_fields, output_fields)[source]¶ Expand output fields list from command line arguments.
-
snapm.command._generic_list_cmd(cmd_args, select, opts, manager, print_fn, data: Optional[object] = None)[source]¶ Generic list command implementation.
Implements a simple list command that applies selection criteria and calls a print_*() API function to display results.
Callers should initialise identifier and select appropriately for the specific command arguments.
- Parameters
cmd_args – the command arguments
select – selection criteria
opts – reporting options object
print_fn – the API call to display results. The function must accept the selection, output_fields, opts, and sort_keys keyword arguments
data (
object) – Optional precomputed data for reporting.
- Returns
Integer status code.
- Return type
int
-
snapm.command._list_cmd(cmd_args)[source]¶ List snapshot sets command handler.
List the snapshot sets that match the given selection criteria as a tabular report, with one snapshot set per row.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._log_debug_command(msg, *args, **kwargs)[source]¶ A wrapper for command subsystem debug logs.
-
snapm.command._mount_cmd(cmd_args)[source]¶ Mount snapshot set command handler.
Mount the specified snapshot set (by default snapshot set mounts appear under /run/snapm/mounts/<name>).
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._plugin_list_cmd(cmd_args)[source]¶ List available plugins.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._prune_cmd(cmd_args)[source]¶ Prune snapshot set command handler.
Attempt to prune the specified sources from the given snapshot set.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main()
-
snapm.command._rename_cmd(cmd_args)[source]¶ Rename snapshot set command handler.
Attempt to rename the specified snapshot set.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._report_obj_types= [<snapm.report.ReportObjType object>, <snapm.report.ReportObjType object>, <snapm.report.ReportObjType object>, <snapm.report.ReportObjType object>, <snapm.report.ReportObjType object>]¶ Report object types table for
snapm.commandreports
-
snapm.command._resize_cmd(cmd_args)[source]¶ Resize snapshot set command handler.
Attempt to resize the snapshots contained in the given snapshot set according to the corresponding size policy.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._revert_cmd(cmd_args)[source]¶ Revert snapshot set command handler.
Attempt to revert the specified snapshot set.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._schedule_create_cmd(cmd_args)[source]¶ Create schedule.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._schedule_delete_cmd(cmd_args)[source]¶ Delete schedule.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main()
-
snapm.command._schedule_disable_cmd(cmd_args)[source]¶ Disable schedule.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main()
-
snapm.command._schedule_edit_cmd(cmd_args)[source]¶ Edit schedule.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._schedule_enable_cmd(cmd_args)[source]¶ Enable schedule.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main()
-
snapm.command._schedule_gc_cmd(cmd_args)[source]¶ Garbage collect schedule.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main().
-
snapm.command._schedule_list_cmd(cmd_args)[source]¶ List configured schedules.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._schedule_show_cmd(cmd_args)[source]¶ List configured schedules.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._shell_cmd(cmd_args)[source]¶ Shell snapshot set command handler.
Start an interactive shell in the given snapshot set. The shell invoked defaults to the SHELL environment variable if set, or the program at /bin/bash otherwise.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._show_cmd(cmd_args)[source]¶ Show snapshot set command handler.
Show the snapshot sets that match the given selection criteria as a multi-line report.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._snapshot_activate_cmd(cmd_args)[source]¶ Activate snapshot command handler.
Attempt to activate the snapshots that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._snapshot_autoactivate_cmd(cmd_args)[source]¶ Autoactivate snapshot command handler.
Attempt to set autoactivation status for the snapshots that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._snapshot_deactivate_cmd(cmd_args)[source]¶ Deactivate snapshot command handler.
Attempt to deactivate the snapshots that match the given selection criteria.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._snapshot_list_cmd(cmd_args)[source]¶ List snapshots command handler.
List the snapshot that match the given selection criteria as a tabular report, with one snapshot per row.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._snapshot_show_cmd(cmd_args)[source]¶ Show snapshots command handler.
Show the snapshots that match the given selection criteria as a multi-line report.
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command._split_cmd(cmd_args)[source]¶ Split snapshot set command handler.
Attempt to split the specified sources from the first snapshot set argument into the second.
- Parameters
cmd_args – Command line arguments for the command.
- Returns
integer status code returned from
main()
-
snapm.command._str_indent(string, indent)[source]¶ Indent all lines of a multi-line string.
Indent each line of the multi line string
stringto the specified indentation level.- Parameters
string – The string to be indented
indent – The number of characters to indent by
- Returns
str
-
snapm.command._umount_cmd(cmd_args)[source]¶ Unmount snapshot set command handler.
Unmount the specified snapshot set (by default from /run/snapm/mounts/<name>).
- Parameters
cmd_args – Command line arguments for the command
- Returns
integer status code returned from
main()
-
snapm.command.create_schedule(manager: snapm.manager._manager.Manager, name: str, sources: List[str], default_size_policy: str, autoindex: bool, calendarspec: Union[str, snapm.manager._calendar.CalendarSpec], policy: snapm.manager._schedule.GcPolicy, boot=False, revert=False)[source]¶ Create a new schedule from a list of mount point and block device source paths.
- Parameters
manager – The manager context to use.
name – The name of the new schedule.
sources – A list of mount point or block devices to snapshot.
default_size_policy – The default size policy for this snapshot set.
autoindex – Enable autoindex names for this schedule.
boot – Create a boot entry for this snapshot set.
revert – Create a revert boot entry for this snapshot set.
autoindex – Treat name as the basename of a recurring snapshot set and generate and append an appropriate index value.
-
snapm.command.create_snapset(manager, name, sources, size_policy=None, boot=False, revert=False, autoindex=False)[source]¶ Create a new snapshot set from a list of mount point and block device source paths.
- Parameters
manager – The manager context to use
name – The name of the new snapshot set
sources – A list of mount point or block devices to snapshot
size_policy – The default size policy for this snapshot set.
boot – Create a boot entry for this snapshot set.
revert – Create a revert boot entry for this snapshot set.
autoindex – Treat name as the basename of a recurring snapshot set and generate and append an appropriate index value.
-
snapm.command.delete_schedule(manager: snapm.manager._manager.Manager, name: str)[source]¶ Delete schedule by name. This disables the schedule and removes all on-disk configuration data.
- Parameters
manager – The manager context to use.
name – The name of the schedule to delete.
-
snapm.command.delete_snapset(manager, selection)[source]¶ Delete snapshot set matching selection criteria.
- Parameters
manager – The manager context to use
selection – Selection criteria for the snapshot set to remove.
-
snapm.command.diff_snapsets(manager: snapm.manager._manager.Manager, diff_from: str, diff_to: str, options: snapm.fsdiff.options.DiffOptions, cache: bool = True, cache_expires: int = - 1, color: str = 'auto') → snapm.fsdiff.engine.FsDiffResults[source]¶ Find differences between snapshot sets or the running system.
Use the difference engine to compare two snapshot sets or a snapshot set and the running system.
The reserved name ‘.’ is used to reference the running system in either
diff_fromordiff_to.- Parameters
manager (
Manager) – TheManagerinstance to use.diff_from (
str) – The name of the snapshot set (or ‘.’ for the running system) to use as the left side of the comparison.diff_to (
str) – The name of the snapshot set (or ‘.’ for the running system) to use as the right side of the comparison.options (
DiffOptions) – Options controlling the comparison.cache (
bool) – Set toFalseto disable use of the diffcache.cache_expires (
int) – Specify cache expiry time in seconds (0 to disable expiry, -1 for built-in default).
- Returns
A file system diff results container.
- Return type
FsDiffResults
-
snapm.command.disable_schedule(manager: snapm.manager._manager.Manager, name: str)[source]¶ Enable an existing schedule. This disables the systemd timer units associated with this schedule.
- Parameters
manager – The manager context to use.
name – The name of the schedule to disable.
-
snapm.command.edit_schedule(manager: snapm.manager._manager.Manager, name: str, sources: Optional[List[str]], default_size_policy: Optional[str], autoindex: bool, calendarspec: Optional[Union[str, snapm.manager._calendar.CalendarSpec]], policy: Optional[snapm.manager._schedule.GcPolicy], boot: Union[None, bool] = None, revert: Union[None, bool] = None)[source]¶ Edit an existing schedule from a list of mount point and block device source paths.
- Parameters
manager – The manager context to use.
name – The name of the new schedule.
sources – A list of mount point or block devices to snapshot.
default_size_policy – The default size policy for this snapshot set.
autoindex – Enable autoindex names for this schedule.
boot – Create a boot entry for this snapshot set.
revert – Create a revert boot entry for this snapshot set.
autoindex – Treat name as the basename of a recurring snapshot set and generate and append an appropriate index value.
-
snapm.command.enable_schedule(manager: snapm.manager._manager.Manager, name: str, start: bool)[source]¶ Enable an existing schedule. This enables the systemd timer units associated with this schedule.
- Parameters
manager – The manager context to use.
name – The name of the schedule to enable.
-
snapm.command.gc_schedule(manager: snapm.manager._manager.Manager, name: str) → List[str][source]¶ Run garbage collection for an existing schedule. This executes the configured garbage collection policy for the schedule named
name.- Parameters
manager – The manager context to use.
name – The name of the schedule to run garbage collection for.
-
snapm.command.print_diffs(_manager, selection=None, output_fields=None, opts=None, sort_keys=None, data: Optional[snapm.fsdiff.engine.FsDiffResults] = None)[source]¶ Print diffs matching selection criteria.
Format a set of
snapm.fsdiff.FsDiffRecordobjects matching the given criteria, and output them as a report to the file given inopts.report_file.Selection criteria may be expressed via a Selection object passed to the call using the
selectionparameter.- Parameters
_manager (
Manager) – Manager context (unused).selection (
Selection) – A Selection object giving selection criteria for the operation (unused).output_fields – a comma-separated list of output fields
opts – output formatting and control options
sort_keys – a comma-separated list of sort keys
data (
Optional[FsDiffResults]) – Pre-computed data for diff report.
-
snapm.command.print_plugins(manager, selection=None, output_fields=None, opts=None, sort_keys=None, data: Optional[object] = None)[source]¶ Print plugins matching selection criteria.
Format a set of
snapm.manager.Pluginobjects matching the given criteria, and output them as a report to the file given inopts.report_file.Selection criteria are currently ignored for plugin reports.
- Parameters
selection – A Selection object giving selection criteria for the operation
output_fields – a comma-separated list of output fields
opts – output formatting and control options
sort_keys – a comma-separated list of sort keys
data (
NoneType) – Optional precomputed data for reporting (currently unused for this report type).
-
snapm.command.print_schedules(manager, selection: Union[None, snapm._snapm.Selection] = None, output_fields: Union[None, str] = None, opts: Union[None, snapm.report.ReportOpts] = None, sort_keys: [None, <class 'str'>] = None, data: object = None)[source]¶ Print schedules matching selection criteria.
Format a set of
snapm.manager.Scheduleobjects matching the given criteria, and output them as a report to the file given inopts.report_file.- Parameters
selection (
Selection) – ASelectionobject giving selection criteria for the operation.output_fields (
str) – A comma-separated list of output fields.opts (
ReportOpts) – Output formatting and control options.sort_keys (
str) – A comma-separated list of sort keys.data (
NoneType) – Optional precomputed data for reporting (currently unused for this report type).
-
snapm.command.print_snapsets(manager, selection=None, output_fields=None, opts=None, sort_keys=None, data: Optional[object] = None)[source]¶ Print snapshot sets matching selection criteria.
Format a set of
snapm.manager.SnapshotSetobjects matching the given criteria, and output them as a report to the file given inopts.report_file.Selection criteria may be expressed via a Selection object passed to the call using the
selectionparameter.- Parameters
selection – A Selection object giving selection criteria for the operation
output_fields – a comma-separated list of output fields
opts – output formatting and control options
sort_keys – a comma-separated list of sort keys
data (
NoneType) – Optional precomputed data for reporting (currently unused for this report type).
-
snapm.command.print_snapshots(manager, selection=None, output_fields=None, opts=None, sort_keys=None, data: Optional[object] = None)[source]¶ Print snapshots matching selection criteria.
Format a set of
snapm.manager.Snapshotobjects matching the given criteria, and output them as a report to the file given inopts.report_file.Selection criteria may be expressed via a Selection object passed to the call using the
selectionparameter.- Parameters
selection – A Selection object giving selection criteria for the operation
output_fields – a comma-separated list of output fields
opts – output formatting and control options
sort_keys – a comma-separated list of sort keys
data (
NoneType) – Optional precomputed data for reporting (currently unused for this report type).
-
snapm.command.prune_snapset(manager, name, sources)[source]¶ Prune snapshots from an existing snapshot set.
Remove snapshots from an existing snapshot set named
name. The snapshot sources listed insourcesare pruned (deleted) from the named snapshot set.- Parameters
name – The name of the snapshot set to prune.
sources – The sources to prune from
name.
- Returns
A
SnapshotSetobject representing the pruned snapshot set
-
snapm.command.rename_snapset(manager, old_name, new_name)[source]¶ Rename a snapshot set from
old_nametonew_name.
-
snapm.command.resize_snapset(manager, sources, name=None, uuid=None, default_size_policy=None)[source]¶ Resize snapshot set by name or UUID.
- Parameters
manager – The manager context to use
sources – A list of mount point or block devices to snapshot
name – The name of the snapshot set to resize.
uuid – The uuid of the snapshot set to resize.
default_size_policy – The default size policy for this snapshot set.
-
snapm.command.revert_snapset(manager, name=None, uuid=None)[source]¶ Revert snapshot set matching selection criteria.
- Parameters
manager – The manager context to use
selection – Selection criteria for the snapshot set to revert.
-
snapm.command.show_schedules(manager, selection=None, _members=False, json=False)[source]¶ Show schedules matching selection criteria.
-
snapm.command.show_snapsets(manager, selection=None, members=False, json=False)[source]¶ Show snapshot sets matching selection criteria.
-
snapm.command.show_snapshots(manager, selection=None, json=False)[source]¶ Show snapshots matching selection criteria.
-
snapm.command.split_snapset(manager, name, new_name, sources)[source]¶ Split an existing snapshot set.
Split the snapshot set named
nameinto two snapshot sets, including all sources listed insourcesin the newly created snapshot set with namenew_name.- Parameters
name – The name of the snapshot set to split.
new_name – The name for the newly created snapshot set.
sources – The sources to split from
nametonew_name.
- Returns
A
SnapshotSetobject representing the snapshot set namednew_name.
snapm.progress module¶
Terminal control and progress indicator
-
snapm.progress.DEFAULT_FPS= 10¶ Default frames-per-second for Throbber classes
-
class
snapm.progress.NullProgress(register: bool = True)[source]¶ Bases:
snapm.progress.ProgressBaseA progress class that produces no output.
-
class
snapm.progress.NullThrobber(header, register: bool = True)[source]¶ Bases:
snapm.progress.ThrobberBaseA throbber class that produces no output.
-
class
snapm.progress.Progress(header, register: bool = True, term_stream: Optional[TextIO] = None, width: Optional[int] = None, width_frac: Optional[float] = None, no_clear: bool = False, tc: Optional[snapm.progress.TermControl] = None)[source]¶ Bases:
snapm.progress.ProgressBaseA 2-line Unicode or ASCII progress bar, which looks like:
- Header: 20% [███████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░]
progress message
or:
- Header: 20% [===========———————————-]
progress message
The progress bar is colored, if the terminal supports color output and adjusts to the width of the terminal.
-
BAR= '${BOLD}${CYAN}%s${NORMAL}: %3d%% ${GREEN}[${BOLD}%s%s${NORMAL}${GREEN}]${NORMAL}\n'¶ Progress bar format string
-
FIXED= 9¶ Length of fixed characters in BAR.
-
__init__(header, register: bool = True, term_stream: Optional[TextIO] = None, width: Optional[int] = None, width_frac: Optional[float] = None, no_clear: bool = False, tc: Optional[snapm.progress.TermControl] = None)[source]¶ Initialise a two-line terminal progress renderer.
- Parameters
header (
str) – The progress header to display.register (
bool) – Register thisProgressfor log callbacks.term_stream (
TextIO) – The terminal stream to write to.width (
int) – An optional width value in characters. If specified the progress bar will occupy this width. Cannot be used withwidth_frac.width_frac (
Optional[float]) – An optional width fraction between [0..1]. If specified the terminal width is multiplied by this value and rounded to the nearest integer to determine the width of the progress bar. Cannot be used withwidth.no_clear (
bool) – For progress indicators that clear and re-draw the content on progress, do not erase the progress bar whenProgressBase.end()is called, leaving it on the terminal for the user to refer to. Ignored byProgressBasechild classes that do not useTerminalControl.tc (
Optional[TermControl]) – An optionalTermControlobject already initialised with aterm_streamvalue. If this argument is set it will override anyterm_streamargument.
- Raises
ValueError – If terminal lacks required capabilities.
-
class
snapm.progress.ProgressBase(register: bool = True)[source]¶ Bases:
abc.ABCAn abstract progress reporting class.
-
FIXED= -1¶
-
__init__(register: bool = True)[source]¶ Initialize base progress state.
Sets default state for lifecycle and rendering configuration.
- Parameters
register (
bool) – Register thisProgressBasefor log callbacks.
-
cancel(message: Union[None, str] = None)[source]¶ End the progress run with error and finalize the display.
- Parameters
message (
Optional[str]) – An optional error message.
-
end(message: Union[None, str] = None)[source]¶ End the progress run and finalize the display.
- Parameters
message (
Optional[str]) – An optional completion message.
-
-
class
snapm.progress.ProgressFactory[source]¶ Bases:
objectA factory for constructing progress objects.
-
static
get_progress(header: str, quiet: bool = False, term_stream: Optional[TextIO] = None, term_control: Optional[snapm.progress.TermControl] = None, width: Optional[int] = None, width_frac: Optional[float] = None, no_clear: bool = False, register: bool = True) → snapm.progress.ProgressBase[source]¶ Return an appropriate ProgressBase implementation.
- Parameters
header (
str) – The progress report header.quiet (
bool) – Suppress all output.term_stream (
Optional[TextIO]) – An optionalTextIOoutput object. Defaults tosys.stdoutif unspecified.term_control (
Optional[TermControl]) – An optionalTermControlobject to use for the progress report.width (
int) – An optional width value in characters. If specified the progress bar will occupy this width. Cannot be used withwidth_frac.width_frac (
Optional[float]) – An optional width fraction between [0..1]. If specified the terminal width is multiplied by this value and rounded to the nearest integer to determine the width of the progress bar. Cannot be used withwidth.no_clear (
bool) – For progress indicators that clear and re-draw the content on progress, do not erase the progress bar whenProgressBase.end()is called, leaving it on the terminal for the user to refer to. Ignored byProgressBasechild classes that do not useTerminalControl.register (
bool) – Register the new object with the log system for notification callbacks.
- Returns
An appropriate progress implementation.
- Return type
ProgressBase
-
static
get_throbber(header: str, quiet: bool = False, style: Union[None, str] = None, term_stream: Optional[TextIO] = None, term_control: Optional[snapm.progress.TermControl] = None, no_clear: bool = False, register: bool = True) → snapm.progress.ThrobberBase[source]¶ Return an appropriate ThrobberBase implementation.
- Parameters
header (
str) – The throbber header.quiet (
bool) – Suppress all output.style (
Optional[str]) – An optional Unicode throbber style string. Ignored if the terminal does not support Unicode encoding.term_stream (
Optional[TextIO]) – An optionalTextIOoutput object. Defaults tosys.stdoutif unspecified.term_control (
Optional[TermControl]) – An optionalTermControlobject to use for the throbber.no_clear (
bool) – For throbber indicators that clear and re-draw the content on throbber, do not erase the throbber bar whenThrobberBase.end()is called, leaving it on the terminal for the user to refer to. Ignored byThrobberBasechild classes that do not useTerminalControl.register (
bool:) – Register the new object with the log system for notification callbacks.
- Returns
An appropriate throbber implementation.
- Return type
ThrobberBase
-
static
-
class
snapm.progress.SimpleProgress(header, register: bool = True, term_stream: Optional[TextIO] = None, width: Optional[int] = None, width_frac: Optional[float] = None)[source]¶ Bases:
snapm.progress.ProgressBaseA simple progress bar that does not rely on terminal capabilities.
-
BAR= '%s: %3d%% [%s%s] (%s)'¶ Progress bar format string
-
DID= '='¶ Bar character for completed work.
-
FIXED= 12¶ Length of fixed characters in BAR.
-
TODO= '-'¶ Bar character for uncompleted work.
-
__init__(header, register: bool = True, term_stream: Optional[TextIO] = None, width: Optional[int] = None, width_frac: Optional[float] = None)[source]¶ Initialise a new
SimpleProgressobject.- Parameters
header (
str) – The progress header to display.register (
bool) – Register thisSimpleProgressfor log callbacks.term_stream (
Optional[TextIO]) – The terminal stream to write to.width (
int) – An optional width value in characters. If specified the progress bar will occupy this width. Cannot be used withwidth_frac.width_frac (
Optional[float]) – An optional width fraction between [0..1]. If specified the terminal width is multiplied by this value and rounded to the nearest integer to determine the width of the progress bar. Cannot be used withwidth.
-
first_update: bool¶
-
header: Optional[str]¶
-
register: bool = <bound method ABCMeta.register of <class 'snapm.progress.SimpleProgress'>>¶
-
registered: bool¶
-
skip_line: bool¶
-
stream: Optional[TextIO]¶
-
term: Optional[snapm.progress.TermControl]¶
-
total: int¶
-
width: int¶
-
-
class
snapm.progress.SimpleThrobber(header: str, register: bool = True, term_stream: Optional[TextIO] = None)[source]¶ Bases:
snapm.progress.ThrobberBaseA simple throbber that does not rely on terminal capabilities.
-
__init__(header: str, register: bool = True, term_stream: Optional[TextIO] = None)[source]¶ Initialise a simple ascii throbber.
- Parameters
header (
str) – The throbber header.register (
bool) – Register thisSimpleThrobberfor log callbacks.term_stream (
Optional[TextIO]) – The terminal stream to write to.
-
-
class
snapm.progress.TermControl(term_stream: Optional[TextIO] = None, color: str = 'auto')[source]¶ Bases:
objectA class for portable terminal control and output.
Uses the curses package to set up appropriate terminal control sequences for the current terminal.
Inspired by and adapted from:
https://code.activestate.com/recipes/475116-using-terminfo-for-portable-color-output-cursor-co/
Copyright Edward Loper and released under the PSF license.
TermControl defines a set of instance variables whose values are initialized to the control sequence necessary to perform a given action. These can be simply included in normal output to the terminal:
>>> term = TermControl() >>> print 'This is '+term.GREEN+'green'+term.NORMAL
Alternatively, the render() method can used, which replaces ‘${action}’ with the string required to perform ‘action’:
>>> term = TermControl() >>> print term.render('This is ${GREEN}green${NORMAL}')
If the terminal doesn’t support a given action, then the value of the corresponding instance variable will be set to ‘’. As a result, the above code will still work on terminals that do not support color, except that their output will not be colored. Also, this means that you can test whether the terminal supports a given action by simply testing the truth value of the corresponding instance variable:
>>> term = TermControl() >>> if term.CLEAR_SCREEN: ... print 'This terminal supports clearning the screen.'
Finally, if the width and height of the terminal are known, then they will be stored in the columns and lines attributes.
-
BELL: str = ''¶ Ring the terminal bell
-
BG_BLACK: str = ''¶ Black background color
-
BG_BLUE: str = ''¶ Blue background color
-
BG_CYAN: str = ''¶ Cyan background color
-
BG_GREEN: str = ''¶ Green background color
-
BG_MAGENTA: str = ''¶ Magenta background color
-
BG_RED: str = ''¶ Red background color
-
BG_WHITE: str = ''¶ White background color
-
BG_YELLOW: str = ''¶ Yellow background color
-
BLACK: str = ''¶ Black foreground color
-
BLINK: str = ''¶ Turn on blink mode
-
BLUE: str = ''¶ Blue foreground color
-
BOL: str = ''¶ Move the cursor to the beginning of the line
-
BOLD: str = ''¶ Turn on bold mode
-
CLEAR_BOL: str = ''¶ Clear to the beginning of the line.
-
CLEAR_EOL: str = ''¶ Clear to the end of the line.
-
CLEAR_EOS: str = ''¶ Clear to the end of the screen
-
CLEAR_SCREEN: str = ''¶ Clear the screen and move to home position
-
CYAN: str = ''¶ Cyan foreground color
-
DIM: str = ''¶ Turn on half-bright mode
-
DOWN: str = ''¶ Move the cursor down one line
-
GREEN: str = ''¶ Green foreground color
-
HIDE_CURSOR: str = ''¶ Make the cursor invisible
-
LEFT: str = ''¶ Move the cursor left one char
-
MAGENTA: str = ''¶ Magenta foreground color
-
NORMAL: str = ''¶ Turn off all modes
-
RED: str = ''¶ Red foreground color
-
REVERSE: str = ''¶ Turn on reverse-video mode
-
RIGHT: str = ''¶ Move the cursor right one char
-
SHOW_CURSOR: str = ''¶ Make the cursor visible
-
UP: str = ''¶ Move the cursor up one line
-
WHITE: str = ''¶ White foreground color
-
YELLOW: str = ''¶ Yellow foreground color
-
__init__(term_stream: Optional[TextIO] = None, color: str = 'auto')[source]¶ Initialize terminal capabilities and size information.
If the output stream is not a tty or terminal setup fails, the instance will have no terminal capabilities (all control attributes remain empty strings or None).
- Parameters
term_stream (
Optional[TextIO]) – Output stream to probe for capabilities.color (
str) – A string to control color rendering: “auto”, “always”, or “never”.
-
columns: Optional[int] = None¶ Terminal width
-
lines: Optional[int] = None¶ Terminal height
-
render(template)[source]¶ Replace each $-substitution with the corresponding control.
Replace each $-substitution in the template string with the corresponding terminal control string (if defined) or an empty string (if not defined).
- Parameters
template (
str) – Template string containing ${NAME} patterns.- Returns
Rendered string with substitutions applied.
- Return type
str
-
-
class
snapm.progress.Throbber(header: str, register: bool = True, style: Union[None, str] = None, term_stream: Optional[TextIO] = None, no_clear: bool = False, tc: Optional[snapm.progress.TermControl] = None)[source]¶ Bases:
snapm.progress.ThrobberBaseA
ThrobberBasesubclass to display a one line Unicode or ASCII throbber for capable terminals.-
STYLES: ClassVar[Dict[str, Union[str, List[str]]]] = {'arrowspinner': '←↖↑↗→↘↓↙', 'ascii': '-\\|/', 'bouncingball': ['[● ]', '[ ● ]', '[ ● ]', '[ ● ]', '[ ● ]', '[ ●]', '[ ● ]', '[ ● ]', '[ ● ]', '[ ● ]', '[● ]'], 'bouncingbar': ['[| ]', '[ | ]', '[ | ]', '[ | ]', '[ | ]', '[ |]', '[ | ]', '[ | ]', '[ | ]', '[ | ]', '[| ]'], 'braillecircle': ['⢎⡰', '⢎⡡', '⢎⡑', '⢎⠱', '⠎⡱', '⢊⡱', '⢌⡱', '⢆⡱'], 'braillewave': '⣾⣽⣻⢿⡿⣟⣯⣷', 'horizontalbars': '█▉▊▋▌▍▎▏▎▍▌▋▊▉█', 'verticalbars': '▁▂▃▄▅▆▇█▇▆▅▄▃▂▁', 'wave': '⠁⠂⠄⡀⢀⠠⠐⠈'}¶
-
__init__(header: str, register: bool = True, style: Union[None, str] = None, term_stream: Optional[TextIO] = None, no_clear: bool = False, tc: Optional[snapm.progress.TermControl] = None)[source]¶ Initialise a new one line throbber instance.
- Parameters
header (
str) – The header string to print.register (
bool) – Register thisThrobberfor log callbacks.style (
Optional[str]) – A Unicode throbber style string. Ignored if the terminal does not support Unicode encoding. Defaults to “wave” if unset.term_stream (
TextIO) – The terminal stream to write to.no_clear (
bool) – For throbber indicators that clear and re-draw the content on progress, do not erase the throbber frame whenThrobberBase.end()is called, leaving it on the terminal for the user to refer to. Ignored byThrobberBasechild classes that do not useTerminalControl.tc (
Optional[TermControl]) – An optionalTermControlobject already initialised with aterm_streamvalue. If this argument is set it will override anyterm_streamargument.
- Raises
ValueError – If terminal lacks required capabilities.
-
-
class
snapm.progress.ThrobberBase(header, register: bool = True)[source]¶ Bases:
abc.ABCAn abstract busy indicator class. Unlike
ProgressBaseclasses the throbber reports progress of a time consuming task where the total number of items is unknown (for instance, generating tree walk lists).-
__init__(header, register: bool = True)[source]¶ Initialize base throbber state.
Sets default state for lifecycle and rendering configuration.
- Parameters
register (
bool) – Register thisThrobberBasefor log callbacks.
-
snapm.report module¶
The snapm reporting module contains a set of classes for creating
simple text based tabular reports for a user-defined set of object
types and fields. No restrictions are placed on the types of object
that can be reported: users of the Report classes may define
additional object types outside the snapm package and include these
types in reports generated by the module.
The fields displayed in a specific report may be selected from the available set of fields by specifying a simple comma-separated string list of field names (in display order). In addition, custom multi-column sorting is possible using a similar string notation.
The Report module is closely based on the device-mapper
reporting engine and shares many features and behaviours with device
mapper reports.
-
class
snapm.report.Field[source]¶ Bases:
objectA
Fieldrepresents an instance of aFieldTypeincluding its associated data values.-
__init__(report, props)[source]¶ Initialise a new Field object.
Initialise a Field object and configure the supplied
reportandpropsattributes.- Parameters
report – The Report that owns this field
props – The FieldProperties object for this field
-
report_idx(value)[source]¶ Report an index value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The index value to set
- Return type
None
-
report_num(value)[source]¶ Report a numeric value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The numeric value to set
- Return type
None
-
report_sha(value)[source]¶ Report a SHA value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The SHA value to set
- Return type
None
-
report_size(value)[source]¶ Report a size value for this Field object.
Set the value for this field to the supplied
value, converted to a human readable string.- Parameters
value – The size value to set in bytes.
- Return type
None
-
report_str(value)[source]¶ Report a string value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The string value to set
- Return type
None
-
report_str_list(value, nosort=False)[source]¶ Report a string list value for this Field object.
Set the value for this field to the strings contained in
value.- Parameters
value – A list of strings
nosort (
bool) – Disable sorting of the provided string list.
- Return type
None
-
report_time(value)[source]¶ Report a time value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The time value to set
- Return type
None
-
report_uuid(value)[source]¶ Report a uuid value for this Field object.
Set the value for this field to the supplied
value.- Parameters
value – The uuid value to set
- Return type
None
-
set_value(report_string, sort_value=None)[source]¶ Report an arbitrary value for this Field object.
Set the value for this field to the supplied
value, and set the field’ssort_valueto the suppliedsort_value.- Parameters
report_string – The string value to set
sort_value – The sort value
- Return type
None
-
-
class
snapm.report.FieldProperties(field_num=None, initial_width=0, width=0, objtype=None, dtype=None, align=None, hidden=False, implicit=False, sort_key=False, sort_dir=None, compact_one=False, compacted=False, sort_posn=None)[source]¶ Bases:
objectProperties of a field instance.
-
class
snapm.report.FieldType[source]¶ Bases:
objectThe
FieldTypeclass describes the properties of a field available in aReportinstance.-
__init__(objtype, name, head, desc, width, dtype, report_fn, align=None)[source]¶ Initialise new FieldType object.
Initialise a new
FieldTypeobject with the specified properties.- Parameters
objtype – The numeric object type ID (power of two)
name – The field name used to select display fields
desc – A human-readable description of the field
width – The default (initial) field width
dtype – The Report data type of the field
report_fn – The field reporting function
align – The field alignment value
- Returns
A new ReportFieldType object
- Return type
ReportFieldType
-
-
class
snapm.report.Report[source]¶ Bases:
objectA class representing a configurable text report with multiple caller-defined fields. An optional title may be provided and the
fieldsargument must contain a list ofFieldobjects describing the required report.-
__init__(types, fields, output_fields, opts, sort_keys, title)[source]¶ Initialise Report.
Initialise a new
Reportobject with the specified fields and output control options.- Parameters
types – List of ReportObjType used in this report.
fields – A list of
Fieldfield descriptions.output_fields – An optional list of output fields to be rendered by this report.
opts – An instance of
ReportOptsor None.
- Returns
A new report object.
- Return type
Report.
-
opts= None¶
-
report_object(obj)[source]¶ Report data for object.
Add a row of data to this
Report. Thedataargument should be an object of the type understood by this report’s fields. It will be passed in turn to each field to obtain data for the current row.- Parameters
obj – the object to report on for this row.
-
-
class
snapm.report.ReportObjType[source]¶ Bases:
objectClass representing a type of object to be reported on. Instances of
ReportObjTypemust specify an identifier, a description, and a data function that will return the correct type of object from a compound object containing data objects of different types. For reports that use only a single object type thedata_fnmember may be simplylambda x: x.-
__init__(objtype, desc, prefix, data_fn)[source]¶ Initialise ReportObjType.
Initialise a new
ReportObjTypeobject with the specifiedobjtype,desc, optionalprefixanddata_fn. Theobjtypemust be an integer power of two that is unique within a given report. Thedata_fnshould accept an object as its only argument and return an object of the requested type.
-
-
class
snapm.report.ReportOpts[source]¶ Bases:
objectOptions controlling the formatting and output of a report.
-
__init__(columns=80, headings=True, buffered=True, separator=' ', field_name_prefix='', unquoted=True, aligned=True, json=False, columns_as_rows=False, report_file=<_io.TextIOWrapper name='<stdout>' mode='w' encoding='utf-8'>)[source]¶ Initialise ReportOpts object.
Initialise a
ReportOptsobject to control output of aReport.- Parameters
columns – the number of columns to use for output.
headings – a boolean indicating whether to output column headings for this report.
buffered – a boolean indicating whether to buffer output from this report.
report_file – a file to which output will be sent.
- Returns
a new
ReportOptsobject.- Return type
<class ReportOpts>
-
snapm.manager._boot module¶
Boot integration for snapshot manager
-
class
snapm.manager._boot.BootCache[source]¶ Bases:
objectSet of caches mapping snapshot sets to boot entries and revert entries.
-
class
snapm.manager._boot.BootEntryCache(entry_arg)[source]¶ Bases:
dictCache mapping snapshot sets to boom
BootEntryinstances.Boot entries in the cache are either snapshot set boot entries or revert entries depending on the value of
entry_arg.
-
snapm.manager._boot.REVERT_ARG= 'snapm.revert'¶ Snapshot set revert kernel command line argument
-
snapm.manager._boot.SNAPSET_ARG= 'snapm.snapset'¶ Snapshot set kernel command line argument
-
snapm.manager._boot._DBUS_MACHINE_ID= '/var/lib/dbus/machine-id'¶ Path to the legacy system machine-id file
-
snapm.manager._boot._DEV_PREFIX= '/dev/'¶ /dev path prefix
-
snapm.manager._boot._MACHINE_ID= '/etc/machine-id'¶ Path to the system machine-id file
-
snapm.manager._boot._OS_RELEASE= '/etc/os-release'¶ Path to the system os-release file
-
snapm.manager._boot._build_swap_list(fstab: snapm._snapm.FsTabReader) → List[str][source]¶ Build a list of command line swap unit definitions for the running system. Swap entries are extracted from /etc/fstab and returned as a list of “WHAT:OPTIONS” strings.
-
snapm.manager._boot._create_boom_boot_entry(version, title, tag_arg, root_device, mounts=None, swaps=None)[source]¶ Create a boom boot entry according to the passed arguments.
- Parameters
version – The UTS release name for the boot entry
title – The title for the boot entry.
tag_arg – A tag argument to be added to the kernel command line and used to associate the entry with a snapshot set name or UUID.
root_device – The root device for the entry. Passed to root=…
mounts – An optional list of mount specifications to use for the boot entry. If defined fstab=no will be appended to the generated kernel command line.
swaps – An optional list of swap specifications to use for the boot entry. Each entry should be in the format “WHAT:OPTIONS”.
-
snapm.manager._boot._create_default_os_profile()[source]¶ Create a default boom OsProfile for the running system. This uses the boom API to run the equivalent of:
boom profile create --from-host.
-
snapm.manager._boot._delete_boot_entry(boot_id)[source]¶ Delete a boom boot entry by ID.
- Parameters
boot_id – The boot identifier to delete.
-
snapm.manager._boot._escape(orig: str) → str[source]¶ Convert literal ‘:’ characters into the hexadecimal escape (:): systemd will decode these when reading systemd.{mount,swap}-extra values.
- Parameters
orig – The original string possibly containing literal ‘:’ characters.
- Returns
An escaped string with ‘:’ replaced by ‘:’.
-
snapm.manager._boot._get_machine_id() → Optional[str][source]¶ Return the current host’s machine-id.
Get the machine-id value for the running system by reading from
/etc/machine-idand return it as a string.- Returns
The
machine_idas a string, orNoneif not available.- Return type
Optional[str]
-
snapm.manager._boot._get_uts_release()[source]¶ Return the UTS release (kernel version) of the running system.
- Returns
A string representation of the UTS release value.
-
snapm.manager._boot._mount_list_to_units(mount_list: List[Tuple[str, str, str, str]]) → List[str][source]¶ Transform a list of
(what, where, fstype, options)tuples into systemd command line mount unit notation.- Parameters
mount_list – The list of mount tuples to transform.
- Returns
A list of systemd.mount-extra= argument strings.
- Return type
List[str]
-
snapm.manager._boot.check_boom_config()[source]¶ Check for boom configuration and create the default config if not found.
-
snapm.manager._boot.create_snapset_boot_entry(snapset, title=None)[source]¶ Create a boom boot entry to boot into the snapshot set represented by
snapset.- Parameters
snapset – The snapshot set for which to create a boot entry.
title – An optional title for the boot entry. If
titleisNonethe boot entry will be titled as “Snapshot snapset_name snapset_time”.
-
snapm.manager._boot.create_snapset_revert_entry(snapset, title=None)[source]¶ Create a boom boot entry to revert the snapshot set represented by
snapset.- Parameters
snapset – The snapshot set for which to create a revert entry.
title – An optional title for the revert entry. If
titleisNonethe revert entry will be titled as “Revert snapset_name snapset_time”.
snapm.manager._calendar module¶
Calendar event abstraction for Snapshot Manager
-
class
snapm.manager._calendar.CalendarSpec(calendarspec: str)[source]¶ Bases:
objectClass representing systemd CalendarSpec expressions.
-
__init__(calendarspec: str)[source]¶ Validate and parse a systemd calendarspec expression into a CalendarSpec object.
- Parameters
calendarspec – A string containing an calendarspec expression.
- Raises
ValueErrorifcalendarspecis not a valid calendarspec expression.
-
__repr__()[source]¶ Return a string representation of this
CalendarSpecinstance in the form of a call to the CalendarSpec initializer.
-
_cond_refresh()[source]¶ Refresh this
CalendarSpecobject’s time-dependent properties if the currentnext_elapsevalue is in the past.
-
property
from_now¶ Return a string representation of the time remaining until this
CalendarSpecnext elapses.- Returns
The time remaining until the next elapse as a string.
- Return type
str
-
property
in_utc¶ Return the next elapse time for this
CalendarSpecobject as an instance ofdatetime.datetimein UTC.- Returns
The next elapse time as a UTC
datetimeobject.- Return type
datetime.datetime
-
property
next_elapse¶ Return the next elapse time for this
CalendarSpecobject as an instance ofdatetime.datetime.- Returns
The next elapse time as a
datetimeobject.- Return type
datetime.datetime
-
property
occurs¶ Trueif thisCalendarSpecobject’s calendar expression will occur in the future, orFalseotherwise.
-
property
original¶ The original form of this
CalendarSpecas a string.
-
snapm.manager._mounts module¶
Mount integration for snapshot manager
-
class
snapm.manager._mounts.Mount(snapset: snapm._snapm.SnapshotSet, mount_root: str, discover: bool = False)[source]¶ Bases:
snapm.manager._mounts.MountBaseRepresentation of a mounted snapshot set, including snapshot set mounts, non-snapshot mounts from /etc/fstab, and bind mounts for API file systems.
-
TYPE= 'Snapshot set'¶
-
__init__(snapset: snapm._snapm.SnapshotSet, mount_root: str, discover: bool = False)[source]¶ Initialize a new Mount instance for the given snapshot set. If
discoverisTruevalidate that themount_rootis an existing mount point for the snapshot set and check for the presence of expected submounts.- Parameters
snapset (
SnapshotSet) – The snapshot set to mount or represent.mount_root (
str) – The absolute path to the root directory where the snapshot set will be mounted or is already mounted.discover (
bool) – If True, validate that mount_root is an existing mount point and discover its submounts. If False, prepare a new mount object without validation.
- Raises
SnapmPathError – If mount_root is not a directory, or if discover is True and mount_root is not a mount point.
-
_abc_impl= <_abc._abc_data object>¶
-
-
class
snapm.manager._mounts.Mounts(manager, mounts_dir: str)[source]¶ Bases:
objectA high-level interface for mounting, unmounting and enumerating snapshot set mounts in the snapm runtime directory (normally /run/snapm/mounts).
-
__init__(manager, mounts_dir: str)[source]¶ Initialise a new Mounts object.
- Parameters
manager – The Manager object that this instance belongs to.
mounts_dir – The directory under which mounts are managed.
-
discover_mounts()[source]¶ Discover and validate existing snapset mounts in the configured mount path.
-
find_mounts(selection: Union[None, snapm._snapm.Selection] = None) → List[snapm.manager._mounts.Mount][source]¶ Return a list of Mount objects describing the currently mounted snapshot sets managed by this Mounts instance.
-
get_sys_mount() → snapm.manager._mounts.SysMount[source]¶ Return an object representing the system root file system mounts.
- Returns
A
SysMountinstance representing ‘/’.- Return type
SysMount
-
mount(snapset: snapm._snapm.SnapshotSet) → snapm.manager._mounts.Mount[source]¶ Mount the snapshot set snapset.
- Parameters
snapset – The snapshot set to operate on.
-
-
class
snapm.manager._mounts.SysMount[source]¶ Bases:
snapm.manager._mounts.MountBaseA class representing the system root file system tree mounted at ‘/’.
-
TYPE= 'System root'¶
-
__init__()[source]¶ Initialize a new SysMount instance for the root file system.
- Raises
SnapmPathError – If root is not a directory, or not a mount point. This should never happen for the root file system.
-
_abc_impl= <_abc._abc_data object>¶
-
snapm.manager._schedule module¶
Snapshot set scheduling abstractions for Snapshot Manager.
-
class
snapm.manager._schedule.GcPolicy(policy_name: str, policy_type: snapm.manager._schedule.GcPolicyType, params: dict)[source]¶ Bases:
objectAn instance of a garbage collection policy.
-
__init__(policy_name: str, policy_type: snapm.manager._schedule.GcPolicyType, params: dict)[source]¶ Initialise a new GcPolicy.
- Parameters
policy_type (
GcPolicyType) – The policy type.params (
dict) – A dictionary of parameters suitable forpolicy_type.
-
__repr__()[source]¶ Return a machine readable string representation of this
GcPolicy.- Returns
A machine readable string.
- Return type
str
-
__str__()[source]¶ Return a human readable string representation of this
GcPolicy.- Returns
A human readable string.
- Return type
str
-
property
enabled¶ Return
Trueif thisGcPolicyand its corresponding timer are enabled, andFalseotherwise.
-
evaluate(sets: List[snapm._snapm.SnapshotSet])[source]¶ Evaluate the list of
SnapshotSetobjects insetsagainst thisGcPolicyand return a list ofSnapshotSetobjects that should be garbage collected.- Parameters
sets (
list[SnapshotSet].) – The list ofSnapshotSetobjects to evaluate, sorted in order of increasing creation date.- Returns
A list of
SnapshotSetobjects to garbage collect.- Return type
list[SnapshotSet]
-
classmethod
from_cmd_args(cmd_args)[source]¶ Initialise garbage collection policy from command line arguments.
Construct a new
GcPolicyobject from the command line arguments incmd_args. TheGcPolicyTypeis determined by thepolicy_typeargument, and the type-specific policy parameters are initialised from the remaining arguments.- Parameters
cmd_args – The command line selection arguments.
- Returns
A new
GcPolicyinstance- Return type
GcPolicy
-
classmethod
from_dict(data)[source]¶ Instantiate a
GcPolicyobject from values indata.- Parameters
data (
dict) – A dictionary describing aGcPolicyinstance.- Returns
An instance of
GcPolicyreflecting the values indata.- Return type
GcPolicy
-
classmethod
from_json(value)[source]¶ Instantiate a
GcPolicyobject from a JSON string invalue.- Parameters
value – A JSON string describing a
GcPolicyParamsinstance.- Returns
An instance of a
GcPolicyParamssubclass reflecting the values in the JSON stringvalue.- Return type
GcPolicyParams
-
property
has_params¶ Return
Trueif thisGcPolicyobject has defined policy parameters orFalseotherwise.- Returns
Trueif parameters are set elseFalse.- Return type
bool
-
json(pretty=False)[source]¶ Return a JSON representation of this
GcPolicy.- Returns
This
GcPolicyas a JSON string.- Return type
str
-
property
name¶ This
GcPolicyinstance’s name.
-
property
params¶ This
GcPolicyinstance’sGcPolicyParamsvalue.
-
property
running¶ Return
Trueif thisGcPolicyand its corresponding timer are enabled, andFalseotherwise.
-
to_dict()[source]¶ Return a dictionary representation of this
GcPolicy.- Returns
This
GcPolicyas a dictionary.- Return type
dict
-
property
type¶ This
GcPolicyinstance’sGcPolicyTypevalue.
-
-
class
snapm.manager._schedule.GcPolicyParams[source]¶ Bases:
objectAbstract base class for garbage collection policy parameters.
-
__str__()[source]¶ Return a human readable string representation of this
GcPolicyParamsinstance.- Returns
A human readable string.
- Return type
str
-
evaluate(sets: List[snapm._snapm.SnapshotSet]) → List[snapm._snapm.SnapshotSet][source]¶ Evaluate the list of
SnapshotSetobjects insetsagainst this set ofGcPolicyParamsand return a list ofSnapshotSetobjects that should be garbage collected.- Parameters
sets (
list[SnapshotSet].) – The list ofSnapshotSetobjects to evaluate, sorted in order of increasing creation date.- Returns
A list of
SnapshotSetobjects to garbage collect.- Return type
list[SnapshotSet]
-
property
has_params¶ Return
Trueif thisGcPolicyParamsobject has defined parameters orFalseotherwise.- Returns
Trueif parameters are set elseFalse.- Return type
bool
-
-
class
snapm.manager._schedule.GcPolicyType(value)[source]¶ Bases:
enum.EnumGarbage collection policy types enum.
-
AGE= 'Age'¶
-
ALL= 'All'¶
-
COUNT= 'Count'¶
-
TIMELINE= 'Timeline'¶
-
-
class
snapm.manager._schedule.Schedule(name: str, sources: List[str], default_size_policy: Optional[str], autoindex: bool, calendarspec: str, gc_policy: snapm.manager._schedule.GcPolicy, boot=False, revert=False)[source]¶ Bases:
objectAn individual snapshot schedule instance with create and garbage collection timers. Tracks timer configuration, name, sources, size policies, enabled/disabled, nr snapshots, next elapse.
-
__init__(name: str, sources: List[str], default_size_policy: Optional[str], autoindex: bool, calendarspec: str, gc_policy: snapm.manager._schedule.GcPolicy, boot=False, revert=False)[source]¶ Initialise a new
Scheduleinstance.- Parameters
name (
str) – The name of theSchedule.sources (
list[str]) – The source specs to include in thisSchedule.default_size_policy (
str) – The default size policy for thisSchedule.autoindex (
bool) – Enable autoindex names for thisSchedule.calendarspec (
str) – TheOnCalendarexpression for thisSchedule.policy (
GcPolicy) – The garbage collection policy for thisSchedule.
- Returns
The new
Scheduleinstance.- Return type
Schedule
-
__repr__()[source]¶ Return a machine-readable representation of this
Schedule.- Returns
A machine-readable string.
- Return type
str
-
__str__()[source]¶ Return a human-readable representation of this
Schedule.- Returns
A human-readable string.
- Return type
str
-
property
autoindex¶ The autoindex property for this
Schedule.
-
property
boot¶ Return
Trueif thisScheduleis configured to enable snapshot set boot entries when creating snapshot sets.
-
property
calendarspec¶ The OnCalendar expression for the timer associated with this
Scheduleinstance.
-
property
default_size_policy¶ The default size policy for this
Schedule.
-
property
enabled¶ Return
Trueif thisScheduleand its corresponding timer are enabled, andFalseotherwise.
-
classmethod
from_dict(data)[source]¶ Instantiate a
Scheduleobject from values indata.- Parameters
data (
dict) – A dictionary describing aScheduleinstance.- Returns
An instance of
Schedulereflecting the values indata.- Return type
GcPolicyParams
-
classmethod
from_file(sched_file)[source]¶ Initialise a new
Scheduleinstance from an on-disk JSON configuration file.- Parameters
sched_file (
str) – The path to the schedule configuration file.- Returns
A new
Scheduleinstance.- Return type
Schedule
-
gc(sets: List[snapm._snapm.SnapshotSet]) → List[str][source]¶ Apply the configured garbage collection policy for this
Schedule.
-
property
gc_policy¶ The garbage collection policy for this
Schedule.
-
json(pretty=False)[source]¶ Return a JSON representation of this
Schedule.- Returns
This
Scheduleas a JSON string.- Return type
str
-
property
name¶ The name of this
Schedule.
-
property
next_elapse¶ Return the
next_elapsetime of thisSchedule’s timer.
-
property
revert¶ Return
Trueif thisScheduleis configured to enable snapshot set revert entries when creating snapshot sets.
-
property
running¶ Return
Trueif thisScheduleand its corresponding timer are enabled, andFalseotherwise.
-
property
sources¶ The source specs value for this
Schedule.
-
snapm.manager._timers module¶
Systemd timer integration for Snapshot Manager.
-
class
snapm.manager._timers.Timer(timer_type: snapm.manager._timers.TimerType, name: str, calendarspec: Union[str, snapm.manager._calendar.CalendarSpec])[source]¶ Bases:
objectHigh-level interface for managing schedling timers.
-
__init__(timer_type: snapm.manager._timers.TimerType, name: str, calendarspec: Union[str, snapm.manager._calendar.CalendarSpec])[source]¶ Initialise a new
Timerobject from the provided arguments.- Parameters
type – A
TimerTypeenum value representing the type of timer to create.name – The name of the timer. The value is used as the instance part of the timer unit name.
calendarspec – A valid calendarspec string, or an instance of the
CalendarSpecclass representing the trigger condition for the timer.
-
disable()[source]¶ Attempt to disable this
Timerinstance. Following a successful call toTimer.disable()the systemd unit is un-configured and no longer loaded. TheTimer.statusisTimerStatus.DISABLED.- Return type
None
-
enable()[source]¶ Attempt to enable this
Timerinstance. Following a successful call toTimer.enable()the systemd unit is configured and loaded, and theTimer.statusisTimerStatus.ENABLED.- Return type
None
-
property
enabled¶ Trueif thisTimeris enabled, andFalseotherwise.- Return type
bool
-
property
from_now¶ Return a string representation of the time remaining until this
Timernext elapses.- Returns
The time remaining until the next elapse as a string.
- Return type
str
-
property
next_elapse¶ Return the next elapse time for this
Timerobject as an instance ofdatetime.datetime.- Returns
The next elapse time as a
datetimeobject.- Return type
datetime.datetime
-
property
occurs¶ Trueif thisTimerwill elapse in the future, andFalseotherwise.- Return type
bool
-
property
running¶ Trueif thisTimeris running, andFalseotherwise.- Return type
bool
-
start()[source]¶ Attempt to start this
Timerinstance. Following a successful call toTimer.start()the systemd unit is ‘active’ / ‘waiting’ and will be invoked when the next elapse time is reached. TheTimer.statusisTimerStatus.RUNNING.- Return type
None
-
property
status¶ Return a
TimerStatusinstance reflecting the status of this timer.- Return type
TimerStatus
-
snapm.manager.plugins module¶
Snapshot manager plugin interface.
-
class
snapm.manager.plugins.Plugin(logger, plugin_cfg)[source]¶ Bases:
abc.ABCAbstract base class for snapshot manager plugins.
-
_abc_impl= <_abc._abc_data object>¶
-
abstract
activate_snapshot(name)[source]¶ Activate the snapshot named
name- Parameters
name – The name of the snapshot to be activated.
-
abstract
can_snapshot(source)[source]¶ Test whether this plugin can snapshot the specified mount point or block device.
- Parameters
source – The block device or mount point path to test.
- Returns
Trueif this plugin can snapshot the file system mounted atmount_point, orFalseotherwise.
-
abstract
check_create_snapshot(origin, snapset_name, timestamp, mount_point, size_policy)[source]¶ Perform pre-creation checks before creating a snapshot.
- Parameters
origin – The origin volume for the snapshot.
snapset_name – The name of the snapshot set to be created.
timestamp – The snapshot set timestamp.
mount_point – The mount point path for this snapshot.
- Raises
SnapmNoSpaceErrorif there is insufficient free space to create the snapshot.
-
abstract
check_resize_snapshot(name, origin, mount_point, size_policy)[source]¶ Check whether this snapshot can be resized to the requested
size_policy. This method returns if the resize can be satisfied and raises an exception if not.- Returns
None
- Raises
SnapmNoSpaceErrorif insufficient space is available to satisfy the requested size policy orSnapmPluginErrorif another reason prevents the snapshot from being resized.
-
abstract
check_revert_snapshot(name, origin)[source]¶ Check whether this snapshot can be reverted or not. This method returns if the current snapshot can be reverted and raises an exception if not.
- Returns
None
- Raises
NotImplementedErrorif this plugin does not support the revert operation,SnapmBusyErrorif the snapshot is already in the process of being reverted to another snapshot state orSnapmPluginErrorif another reason prevents the snapshot from being merged.
-
abstract
create_snapshot(origin, snapset_name, timestamp, mount_point, size_policy)[source]¶ Create a snapshot of
originin the snapset namedsnapset_name.- Parameters
origin – The origin volume for the snapshot.
snapset_name – The name of the snapshot set to be created.
timestamp – The snapshot set timestamp.
mount_point – The mount point path for this snapshot.
- Raises
SnapmNoSpaceErrorif there is insufficient free space to create the snapshot.
-
abstract
deactivate_snapshot(name)[source]¶ Deactivate the snapshot named
name- Parameters
name – The name of the snapshot to be deactivated.
-
abstract
delete_snapshot(name)[source]¶ Delete the snapshot named
name- Parameters
name – The name of the snapshot to be removed.
-
abstract
discover_snapshots()[source]¶ Discover snapshots managed by this plugin class.
Returns a list of objects that are a subclass of
Snapshot. :returns: A list of snapshots discovered by this plugin class.
-
name= 'plugin'¶
-
abstract
origin_from_mount_point(mount_point)[source]¶ Return a string representing the origin from a given mount point path.
- Parameters
mount_point – The mount point path.
-
abstract
rename_snapshot(old_name, origin, snapset_name, timestamp, mount_point)[source]¶ Rename the snapshot named
old_nameaccording to the provided snapshot field values.- Parameters
old_name – The original name of the snapshot to be renamed.
origin – The origin volume for the snapshot.
snapset_name – The new name of the snapshot set.
timestamp – The snapshot set timestamp.
mount_point – The mount point of the snapshot.
-
abstract
resize_snapshot(name, origin, mount_point, size_policy)[source]¶ Attempt to resize the snapshot
nameto the requestedsize_policy. This method returns if the resize can be satisfied and raises an exception if not.- Returns
None
- Raises
SnapmNoSpaceErrorif insufficient space is available to satisfy the requested size policy orSnapmPluginErrorif another reason prevents the snapshot from being resized.
-
abstract
revert_snapshot(name)[source]¶ Request to revert a snapshot and revert the content of the origin volume to its state at the time of the snapshot.
This may be deferred until the next device activation or mount operation for the respective volume.
- Parameters
name – The name of the snapshot to revert.
-
abstract
set_autoactivate(name, auto=False)[source]¶ Set the autoactivation state of the snapshot named
name.- Parameters
name – The name of the snapshot to be modified.
auto –
Trueto enable autoactivation orFalseotherwise.
-
snapshot_class¶ alias of
snapm._snapm.Snapshot
-
version= '0.2.0'¶
-
-
snapm.manager.plugins.decode_mount_point(mount_str)[source]¶ Parse the mount point component of a snapshot name.
-
snapm.manager.plugins.device_from_mount_point(mount_point)[source]¶ Convert a mount point path to a corresponding device path.
Return the device corresponding to the file system mount point
mount_pointaccording to /proc/self/mounts.
-
snapm.manager.plugins.encode_mount_point(mount_point)[source]¶ Encode mount point paths.
Encode a mount point for use in a snapshot name by replacing the path separator with ‘-‘.
-
snapm.manager.plugins.format_snapshot_name(origin, snapset_name, timestamp, mount_point)[source]¶ Format structured snapshot name.
Format a snapshot name according to the snapshot manager naming format.
snapm.fsdiff.changes module¶
File system entry change detection and classification.
-
class
snapm.fsdiff.changes.ChangeDetector[source]¶ Bases:
objectClass to detect and classify changes in
FsEntryobjects.-
detect_added(new_entry: snapm.fsdiff.treewalk.FsEntry, options: snapm.fsdiff.options.DiffOptions) → List[snapm.fsdiff.changes.FileChange][source]¶ Detect all changes for a newly added file.
- Parameters
new_entry (
FsEntry) – The updated file system entry.options (
DiffOptions) – Change detection options.
- Returns
A list of changes to the file system entry.
- Return type
List[FileChange]
-
detect_changes(old_entry: snapm.fsdiff.treewalk.FsEntry, new_entry: snapm.fsdiff.treewalk.FsEntry, options: snapm.fsdiff.options.DiffOptions) → List[snapm.fsdiff.changes.FileChange][source]¶ Detect all changes between two file system entries.
- Parameters
old_entry (
FsEntry) – The original file system entry.new_entry (
FsEntry) – The updated file system entry.options (
DiffOptions) – Change detection options.
- Returns
A list of changes to the file system entry.
- Return type
List[FileChange]
-
detect_removed(old_entry: snapm.fsdiff.treewalk.FsEntry, options: snapm.fsdiff.options.DiffOptions) → List[snapm.fsdiff.changes.FileChange][source]¶ Detect all changes for a removed file.
- Parameters
old_entry (
FsEntry) – The updated file system entry.options (
DiffOptions) – Change detection options.
- Returns
A list of changes to the file system entry.
- Return type
List[FileChange]
-
-
class
snapm.fsdiff.changes.ChangeType(value)[source]¶ Bases:
enum.EnumEnum representing different types of file system entry change.
-
CONTENT= 'content'¶
-
OWNERSHIP= 'ownership'¶
-
PERMISSIONS= 'permissions'¶
-
SYMLINK_TARGET= 'symlink_target'¶
-
TIMESTAMPS= 'timestamps'¶
-
XATTRS= 'extended_attributes'¶
-
-
class
snapm.fsdiff.changes.FileChange(change_type: snapm.fsdiff.changes.ChangeType, old_value: Union[None, str] = None, new_value: Union[None, str] = None, description: str = '')[source]¶ Bases:
objectRepresentation of a file system entry change.
-
__init__(change_type: snapm.fsdiff.changes.ChangeType, old_value: Union[None, str] = None, new_value: Union[None, str] = None, description: str = '')[source]¶ Initialise a new
FileChangeobject.- Parameters
change_type (
ChangeType) – The type of change.old_value (
Optional[str]) – The original value.new_value (
Optional[str]) – The changed value.description (
str) – A string description of the change.
-
snapm.fsdiff.contentdiff module¶
Content-aware diff support.
-
class
snapm.fsdiff.contentdiff.BinaryContentDiffer[source]¶ Bases:
snapm.fsdiff.contentdiff.ContentDifferBaseBinary file content differ.
-
_abc_impl= <_abc._abc_data object>¶
-
binary_types= (<FileTypeCategory.BINARY: 'binary'>, <FileTypeCategory.IMAGE: 'image'>, <FileTypeCategory.AUDIO: 'audio'>, <FileTypeCategory.VIDEO: 'video'>, <FileTypeCategory.ARCHIVE: 'archive'>, <FileTypeCategory.EXECUTABLE: 'executable'>, <FileTypeCategory.DATABASE: 'database'>, <FileTypeCategory.DOCUMENT: 'document'>)¶
-
can_handle(file_type_info: snapm.fsdiff.filetypes.FileTypeInfo) → bool[source]¶ Return True if this differ can handle the given file type.
- Parameters
file_type_info (
FileTypeInfo) – File type information for the file to compare.- Returns
Trueif this content differ can handle this file.- Return type
bool
-
generate_diff(_old_path: Optional[pathlib.Path], _new_path: Optional[pathlib.Path], old_entry: Optional[snapm.fsdiff.treewalk.FsEntry], new_entry: Optional[snapm.fsdiff.treewalk.FsEntry]) → snapm.fsdiff.contentdiff.ContentDiff[source]¶ Generate binary diff summary.
- Parameters
_old_path (
Optional[Path]) –Pathdescribing the original path to diff (unused)._new_path (
Optional[Path]) –Pathdescribing the updated path to diff (unused).old_entry (
Optional[FsEntry]) – The originalFsEntryto diff.new_entry (
Optional[FsEntry]) – The updatedFsEntryto diff.
- Returns
A diff of the two entries.
- Return type
ContentDiff
-
property
priority¶ Priority for selection when multiple differs match (higher = preferred)
- Returns
Integer priority level.
- Return type
int
-
-
class
snapm.fsdiff.contentdiff.ContentDiff(diff_type: str, old_content: Union[None, str] = None, new_content: Union[None, str] = None, summary: str = '')[source]¶ Bases:
objectRepresents a content-aware diff between two files.
-
__init__(diff_type: str, old_content: Union[None, str] = None, new_content: Union[None, str] = None, summary: str = '')[source]¶ Initialise a new
ContentDiffobject.- Parameters
diff_type (
str) – The type of diff to perform.old_content (
str) – The original content.new_content (
str) – The updated content.summary (
str) – A summary of the difference.
-
-
class
snapm.fsdiff.contentdiff.ContentDifferBase[source]¶ Bases:
abc.ABCBase class for content-aware diff implementations.
-
_abc_impl= <_abc._abc_data object>¶
-
abstract
can_handle(file_type_info: snapm.fsdiff.filetypes.FileTypeInfo) → bool[source]¶ Return True if this differ can handle the given file type.
- Parameters
file_type_info (
FileTypeInfo) – File type information for the file to compare.- Returns
Trueif this content differ can handle this file.- Return type
bool
-
abstract
generate_diff(old_path: Optional[pathlib.Path], new_path: Optional[pathlib.Path], old_entry: Optional[snapm.fsdiff.treewalk.FsEntry], new_entry: Optional[snapm.fsdiff.treewalk.FsEntry]) → snapm.fsdiff.contentdiff.ContentDiff[source]¶ Generate content diff between two files.
- Parameters
old_path (
Optional[Path]) –Pathdescribing the original path to diff.new_path (
Optional[Path]) –Pathdescribing the updated path to diff.old_entry (
Optional[FsEntry]) – The originalFsEntryto diff.new_entry (
Optional[FsEntry]) – The updatedFsEntryto diff.
- Returns
A diff of the two entries.
- Return type
ContentDiff
-
abstract property
priority¶ Priority for selection when multiple differs match (higher = preferred)
- Returns
Integer priority level.
- Return type
int
-
-
class
snapm.fsdiff.contentdiff.ContentDifferManager[source]¶ Bases:
objectManager for content-aware diff implementations.
-
generate_content_diff(old_path: Optional[pathlib.Path], new_path: Optional[pathlib.Path], old_entry: Optional[snapm.fsdiff.treewalk.FsEntry], new_entry: Optional[snapm.fsdiff.treewalk.FsEntry]) → Optional[snapm.fsdiff.contentdiff.ContentDiff][source]¶ Generate content diff using appropriate differ.
- Parameters
old_path (
Optional[Path]) –Pathdescribing the original path to diff.new_path (
Optional[Path]) –Pathdescribing the updated path to diff.old_entry (
Optional[FsEntry]) – The originalFsEntryto diff.new_entry (
Optional[FsEntry]) – The updatedFsEntryto diff.
- Returns
A diff of the two entries.
- Return type
Optional[ContentDiff]
-
get_differ_for_file(file_type_info: snapm.fsdiff.filetypes.FileTypeInfo) → snapm.fsdiff.contentdiff.ContentDifferBase[source]¶ Get the best content differ for a file type.
- Parameters
file_type_info (
FileTypeInfo) – The file type to find a differ for.- Returns
An appropriate differ for
file_type_info.- Return type
A
ContentDifferBasesubclass.
-
register_differ(differ: snapm.fsdiff.contentdiff.ContentDifferBase)[source]¶ Register a new content differ.
-
-
class
snapm.fsdiff.contentdiff.JsonContentDiffer[source]¶ Bases:
snapm.fsdiff.contentdiff.ContentDifferBaseJSON-aware content differ.
-
_abc_impl= <_abc._abc_data object>¶
-
can_handle(file_type_info: snapm.fsdiff.filetypes.FileTypeInfo) → bool[source]¶ Return True if this differ can handle the given file type.
- Parameters
file_type_info (
FileTypeInfo) – File type information for the file to compare.- Returns
Trueif this content differ can handle this file.- Return type
bool
-
generate_diff(old_path: Optional[pathlib.Path], new_path: Optional[pathlib.Path], old_entry: Optional[snapm.fsdiff.treewalk.FsEntry], new_entry: Optional[snapm.fsdiff.treewalk.FsEntry]) → snapm.fsdiff.contentdiff.ContentDiff[source]¶ Generate structured JSON diff.
- Parameters
old_path (
Optional[Path]) –Pathdescribing the original path to diff.new_path (
Optional[Path]) –Pathdescribing the updated path to diff.old_entry (
Optional[FsEntry]) – The originalFsEntryto diff.new_entry (
Optional[FsEntry]) – The updatedFsEntryto diff.
- Returns
A diff of the two entries.
- Return type
ContentDiff
-
property
priority¶ Priority for selection when multiple differs match (higher = preferred)
- Returns
Integer priority level.
- Return type
int
-
-
class
snapm.fsdiff.contentdiff.TextContentDiffer[source]¶ Bases:
snapm.fsdiff.contentdiff.ContentDifferBaseDefault text-based content differ.
-
_abc_impl= <_abc._abc_data object>¶
-
can_handle(file_type_info: snapm.fsdiff.filetypes.FileTypeInfo) → bool[source]¶ Return True if this differ can handle the given file type.
- Parameters
file_type_info (
FileTypeInfo) – File type information for the file to compare.- Returns
Trueif this content differ can handle this file.- Return type
bool
-
generate_diff(old_path: Optional[pathlib.Path], new_path: Optional[pathlib.Path], old_entry: Optional[snapm.fsdiff.treewalk.FsEntry], new_entry: Optional[snapm.fsdiff.treewalk.FsEntry]) → snapm.fsdiff.contentdiff.ContentDiff[source]¶ Generate unified diff for text files.
- Parameters
old_path (
Optional[Path]) –Pathdescribing the original path to diff.new_path (
Optional[Path]) –Pathdescribing the updated path to diff.old_entry (
Optional[FsEntry]) – The originalFsEntryto diff.new_entry (
Optional[FsEntry]) – The updatedFsEntryto diff.
- Returns
A diff of the two entries.
- Return type
ContentDiff
-
property
priority¶ Priority for selection when multiple differs match (higher = preferred)
- Returns
Integer priority level.
- Return type
int
-
snapm.fsdiff.engine module¶
File system diff engine
-
class
snapm.fsdiff.engine.DiffEngine[source]¶ Bases:
objectCore class for generating fsdiff comparisons.
-
static
_best_sibling_proximity(orig_path: str, candidates: List[Tuple[str, snapm.fsdiff.treewalk.FsEntry]]) → Tuple[str, snapm.fsdiff.treewalk.FsEntry][source]¶ Sibling proximity heuristic: choose the “best” move destination when multiple candidates exist.
- Parameters
orig_path (
str) – The original path before the move.candidates (
List[Tuple[str, FsEntry]]) – Possible candidates for the destination, as a list of (path, entry) pairs.
- Returns
The winning (path, entry) pair.
- Return type
Tuple[str, FsEntry]
-
_detect_moves(diffs: List[snapm.fsdiff.engine.FsDiffRecord], tree_a: Dict[str, snapm.fsdiff.treewalk.FsEntry], tree_b: Dict[str, snapm.fsdiff.treewalk.FsEntry], options: snapm.fsdiff.options.DiffOptions, term_control: Optional[snapm.progress.TermControl] = None) → List[snapm.fsdiff.engine.FsDiffRecord][source]¶ Detect file moves/renames by matching content hashes
- Parameters
diffs (
List[FsDiffRecord]) – A list of file system diff records to inspect.tree_a (
Dict[str, FsEntry]) – The first file system tree to compare: a dictionary of path name -> file system entry mappings.tree_b (
Dict[str, FsEntry]) – The second file system tree to compare: a dictionary of path name -> file system entry mappings.options (
DiffOptions) – Options to apply to the diff generation.term_control (
TermControl) – ATermControlinstance to use for rendering color output.
- Returns
Updated list of diff records with moves detected.
- Return type
List[FsDiffRecord]
-
_effective_changes(changes: List[snapm.fsdiff.changes.FileChange], options: snapm.fsdiff.options.DiffOptions) → List[snapm.fsdiff.changes.FileChange][source]¶ Elide ignored change types in
changes.- Parameters
changes (
List[FileChange]) – The list of changes to examine.options (
DiffOptions) – Effective diff options.
- Returns
Changes pruned according to options.
- Return type
List[FileChange]
-
static
_is_move_diff(diff, src_path, dest_path)[source]¶ Return
Trueifdiffreflects a move diff type for the currentpath/dest_pathorFalseotherwise.- Parameters
diff – The
FsDiffRecordto inspect.src_path – The original path to check.
dest_path – The destination path to check.
-
compute_diff(tree_a: Dict[str, snapm.fsdiff.treewalk.FsEntry], tree_b: Dict[str, snapm.fsdiff.treewalk.FsEntry], options: Optional[snapm.fsdiff.options.DiffOptions] = None, term_control: Optional[snapm.progress.TermControl] = None) → snapm.fsdiff.engine.FsDiffResults[source]¶ Main diff computation logic.
- Parameters
tree_a (
Dict[str, FsEntry]) – The first file system tree to compare: a dictionary of path name -> file system entry mappings.tree_b (
Dict[str, FsEntry]) – The second file system tree to compare: a dictionary of path name -> file system entry mappings.options (
DiffOptions) – Options to apply to the diff generation.term_control (
TermControl) – ATermControlinstance to use for rendering color output.
- Returns
An
FsDiffResultsinstance containingFsDiffRecordobjects.- Return type
FsDiffResults
-
static
-
class
snapm.fsdiff.engine.FsDiffRecord(path: str, diff_type: snapm.fsdiff.difftypes.DiffType, old_entry: Optional[snapm.fsdiff.treewalk.FsEntry] = None, new_entry: Optional[snapm.fsdiff.treewalk.FsEntry] = None)[source]¶ Bases:
objectDiff record compatible with snapm.report system Represents a single file/directory change
-
__init__(path: str, diff_type: snapm.fsdiff.difftypes.DiffType, old_entry: Optional[snapm.fsdiff.treewalk.FsEntry] = None, new_entry: Optional[snapm.fsdiff.treewalk.FsEntry] = None)[source]¶ Initialise a new
FsDiffRecordobject.- Parameters
path (
str) – A string describing the path for this diff record.diff_type (
DiffType) – The diff type for this diff record.old_entry – The original entry for the comparison.
new_entry – The updated entry for the comparison.
-
__str__() → str[source]¶ Return a string representation of this
FsDiffRecordobject.- Returns
A human readable representation of this
FsDiffRecord.- Return type
str
-
_get_file_category() → str[source]¶ Get file category for reporting
- Returns
The file category for this diff record.
- Return type
str
-
_get_file_type() → str[source]¶ Get file type for reporting.
- Returns
A description of the file type for this diff record.
- Return type
str
-
_get_file_type_desc() → str[source]¶ Get file type description for reporting.
- Returns
A detailed description of the file type for this diff record.
- Return type
str
-
add_change(change: snapm.fsdiff.changes.FileChange)[source]¶ Add a detected change.
- Parameters
change (
FileChange) – The file change to record.
-
json(pretty=False) → str[source]¶ Return a string representation of this
FsDiffRecordin JSON notation.- Parameters
pretty (
bool) – Indent JSON to be human readable.- Returns
A JSON representation of this instance.
- Return type
str
-
set_content_diff(content_diff: snapm.fsdiff.contentdiff.ContentDiff)[source]¶ Set content-level diff.
- Parameters
content_diff (
ContentDiff) – The content diff for this diff record.
-
-
class
snapm.fsdiff.engine.FsDiffResults(records: List[snapm.fsdiff.engine.FsDiffRecord], options: snapm.fsdiff.options.DiffOptions, timestamp: int, count: int = 0)[source]¶ Bases:
objectContainer for filesystem diff results with formatting methods.
-
DIFF_FORMATS: ClassVar[List[str]] = ['paths', 'full', 'short', 'json', 'diff', 'summary', 'tree']¶ Constant for the names of the string diff formats
-
__init__(records: List[snapm.fsdiff.engine.FsDiffRecord], options: snapm.fsdiff.options.DiffOptions, timestamp: int, count: int = 0)[source]¶ Initialize self. See help(type(self)) for accurate signature.
-
__repr__() → str[source]¶ Return a machine-readable representation of this instance.
- Returns
FsDiffResultsconstructor style string.- Return type
str
-
property
added¶ Return added changes in this
FsDiffResultsinstance.- Returns
Changes with
DiffType.ADDEDtype.- Return type
List[FsDiffRecord]
-
property
content_changes¶ Return the number of content changes in this
FsDiffResultsinstance.- Returns
Count of changes with content diff.
- Return type
int
-
diff(diffstat: bool = False, color: str = 'auto', term_control: Optional[snapm.progress.TermControl] = None) → str[source]¶ Return unified diff representation of content changes for this instance.
- Parameters
diffstat (
bool) – Include “diffstat”-like change summary.color (
str) – A string to control color diff rendering: “auto”, “always”, or “never”.term_control (
Optional[TermControl]) – An optionalTermControlinstance to use for formatting. The supplied instance overrides anycolorargument if set.
- Returns
unified diff string description of file system changes.
- Return type
str
-
full() → str[source]¶ Return a string with full
FsDiffRecordcontent for this instance.- Returns
String description of file system changes.
- Return type
str
-
json(pretty: bool = False) → str[source]¶ Return JSON representation of
FsDiffRecordcontent for this instance.- Returns
JSON string description of file system changes.
- Return type
str
-
property
modified¶ Return modified changes in this
FsDiffResultsinstance.- Returns
Changes with
DiffType.MODIFIEDtype.- Return type
List[FsDiffRecord]
-
property
moved¶ Return moved changes in this
FsDiffResultsinstance.- Returns
Changes with
DiffType.MOVEDtype.- Return type
List[FsDiffRecord]
-
paths() → List[str][source]¶ Return a list of paths that changed in this
FsDiffResults.- Returns
Path list.
- Return type
List[str]
-
property
removed¶ Return removed changes in this
FsDiffResultsinstance.- Returns
Changes with
DiffType.REMOVEDtype.- Return type
List[FsDiffRecord]
-
short() → str[source]¶ Return brief summary of
FsDiffRecordcontent for this instance.- Returns
Brief string description of file system changes.
- Return type
str
-
summary(diffstat: bool = False, color: str = 'auto', term_control: Optional[snapm.progress.TermControl] = None) → str[source]¶ Return a summary of this
FsDiffResultsinstance.- Parameters
diffstat (
bool) – Include “diffstat”-like change summary.color (
str) – A string to control color rendering: “auto”, “always”, or “never”.term_control (
Optional[TermControl]) – An optionalTermControlinstance to use for formatting. The supplied instance overrides anycolorargument if set.
- Returns
A string summarizing this instance.
- Return type
str
-
property
total_changes¶ Return the total number of changes in this
FsDiffResultsinstance: equivalent tolen(self).- Returns
Count of changes.
- Return type
int
-
tree(color: str = 'auto', desc: str = 'none', term_control: Optional[snapm.progress.TermControl] = None) → str[source]¶ Render a
DiffTreeof thisFsDiffResultsinstance.- Parameters
color (
str) – A string to control color tree rendering: “auto”, “always”, or “never”.desc (
Optional[str]) – Include descriptions: “short” for brief description, “full” for complete change descriptions or “none” to omit.term_control (
Optional[TermControl]) – An optionalTermControlinstance to use for formatting. The supplied instance overrides anycolorargument if set.
- Returns
A string representation of a difference tree
- Return type
str
-
property
type_changed¶ Return type_changed changes in this
FsDiffResultsinstance.- Returns
Changes with
DiffType.TYPE_CHANGEDtype.- Return type
List[FsDiffRecord]
-
-
snapm.fsdiff.engine._log_debug_fsdiff(msg, *args, **kwargs)[source]¶ A wrapper for fsdiff subsystem debug logs.
-
snapm.fsdiff.engine._log_debug_fsdiff_extra(msg, *args, **kwargs)[source]¶ A wrapper for fsdiff subsystem debug logs.
-
snapm.fsdiff.engine.render_diff_stat(records: List[snapm.fsdiff.engine.FsDiffRecord], term_control: snapm.progress.TermControl) → str[source]¶ Render a diffstat-style summary for the given records.
- Parameters
records (
FsDiffRecord) – Diff records with content diffs.term_control (
TermControl) – ATermControlinstance to use for rendering color output.
- Returns
Diffstat-style summary string.
- Return type
str
-
snapm.fsdiff.engine.render_unified_diff(record: snapm.fsdiff.engine.FsDiffRecord, tc: Optional[snapm.progress.TermControl]) → str[source]¶ Render a unified diff for a modified file.
- Parameters
record (
FsDiffRecord) – The diff record to render.tc (
Optional[TermControl]) – An optionalTermControlinstance to use for rendering color output.
- Returns
Rendered unified diff string.
- Return type
str
snapm.fsdiff.filetypes module¶
File type information support.
-
class
snapm.fsdiff.filetypes.FileTypeCategory(value)[source]¶ Bases:
enum.EnumEnum for file type categories.
-
ARCHIVE= 'archive'¶
-
AUDIO= 'audio'¶
-
BINARY= 'binary'¶
-
BINARY_LOG= 'binary_log'¶
-
BLOCK= 'block'¶
-
CERTIFICATE= 'certificate'¶
-
CHAR= 'char'¶
-
CONFIG= 'config'¶
-
DATABASE= 'database'¶
-
DIRECTORY= 'directory'¶
-
DOCUMENT= 'document'¶
-
EXECUTABLE= 'executable'¶
-
FIFO= 'FIFO'¶
-
IMAGE= 'image'¶
-
LOG= 'log'¶
-
SOCK= 'socket'¶
-
SOURCE_CODE= 'source_code'¶
-
SYMLINK= 'symlink'¶
-
TEXT= 'text'¶
-
UNKNOWN= 'unknown'¶
-
VIDEO= 'video'¶
-
-
class
snapm.fsdiff.filetypes.FileTypeDetector[source]¶ Bases:
objectDetect file types using
magicfrom python3-file-magic.-
_categorize_file(mime_type: str, file_path: pathlib.Path) → snapm.fsdiff.filetypes.FileTypeCategory[source]¶ Categorize file based on MIME type and path patterns.
- Parameters
mime_type (
str) – Detected file MIME type.file_path (
Path) – Path to the file to categorize.
- Returns
File type categorization.
- Return type
FileTypeCategory
-
_guess_file_type(file_path: pathlib.Path) → snapm.fsdiff.filetypes.FileTypeInfo[source]¶ Attempt to guess file type based on extension and file path without using python-magic.
- Parameters
file_path (
Path) – The path to guess file type for.- Returns
A
FileTypeInfoobject with a best-effort guess of the file type.- Return type
FileTypeInfo
-
category_rules: ClassVar[Dict[str, snapm.fsdiff.filetypes.FileTypeCategory]] = {'application/gzip': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/java-archive': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/javascript': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/json': <FileTypeCategory.CONFIG: 'config'>, 'application/ld+json': <FileTypeCategory.CONFIG: 'config'>, 'application/mbox': <FileTypeCategory.DATABASE: 'database'>, 'application/msword': <FileTypeCategory.DOCUMENT: 'document'>, 'application/pdf': <FileTypeCategory.DOCUMENT: 'document'>, 'application/pkix-cert': <FileTypeCategory.CERTIFICATE: 'certificate'>, 'application/rtf': <FileTypeCategory.DOCUMENT: 'document'>, 'application/toml': <FileTypeCategory.CONFIG: 'config'>, 'application/vnd.android.package-archive': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/vnd.microsoft.portable-executable': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/vnd.ms-excel': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.ms-powerpoint': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.oasis.opendocument.spreadsheet': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.oasis.opendocument.text': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.openxmlformats-officedocument.presentationml.presentation': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.openxmlformats-officedocument.wordprocessingml.document': <FileTypeCategory.DOCUMENT: 'document'>, 'application/vnd.sqlite3': <FileTypeCategory.DATABASE: 'database'>, 'application/x-7z-compressed': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-bat': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-bzip2': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-csh': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-dbf': <FileTypeCategory.DATABASE: 'database'>, 'application/x-dosexec': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-elf': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-executable': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-fish': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-gzip': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-iso9660-image': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-javascript': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-ksh': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-lzip': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-lzma': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-mach-binary': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-msdownload': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-object': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-pem-file': <FileTypeCategory.CERTIFICATE: 'certificate'>, 'application/x-pie-executable': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-rar': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-rar-compressed': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-sh': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/x-sharedlib': <FileTypeCategory.EXECUTABLE: 'executable'>, 'application/x-sqlite3': <FileTypeCategory.DATABASE: 'database'>, 'application/x-tar': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-x509-ca-cert': <FileTypeCategory.CERTIFICATE: 'certificate'>, 'application/x-xz': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/x-yaml': <FileTypeCategory.CONFIG: 'config'>, 'application/x-zsh': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'application/xml': <FileTypeCategory.CONFIG: 'config'>, 'application/yaml': <FileTypeCategory.CONFIG: 'config'>, 'application/zip': <FileTypeCategory.ARCHIVE: 'archive'>, 'application/zstd': <FileTypeCategory.ARCHIVE: 'archive'>, 'audio/': <FileTypeCategory.AUDIO: 'audio'>, 'font/': <FileTypeCategory.BINARY: 'binary'>, 'image/': <FileTypeCategory.IMAGE: 'image'>, 'inode/blockdevice': <FileTypeCategory.BLOCK: 'block'>, 'inode/chardevice': <FileTypeCategory.CHAR: 'char'>, 'inode/directory': <FileTypeCategory.DIRECTORY: 'directory'>, 'inode/fifo': <FileTypeCategory.FIFO: 'FIFO'>, 'inode/socket': <FileTypeCategory.SOCK: 'socket'>, 'inode/symlink': <FileTypeCategory.SYMLINK: 'symlink'>, 'model/': <FileTypeCategory.BINARY: 'binary'>, 'text/': <FileTypeCategory.TEXT: 'text'>, 'text/asciidoc': <FileTypeCategory.DOCUMENT: 'document'>, 'text/css': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/html': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/javascript': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/markdown': <FileTypeCategory.DOCUMENT: 'document'>, 'text/rtf': <FileTypeCategory.DOCUMENT: 'document'>, 'text/troff': <FileTypeCategory.DOCUMENT: 'document'>, 'text/vbs': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-awk': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-bibtex': <FileTypeCategory.DOCUMENT: 'document'>, 'text/x-c': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-c++': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-diff': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-ini': <FileTypeCategory.CONFIG: 'config'>, 'text/x-java-source': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-lua': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-makefile': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-nfo': <FileTypeCategory.DOCUMENT: 'document'>, 'text/x-perl': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-powershell': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-python': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-script.python': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-sed': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-shellscript': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-tcl': <FileTypeCategory.SOURCE_CODE: 'source_code'>, 'text/x-tex': <FileTypeCategory.DOCUMENT: 'document'>, 'text/x-toml': <FileTypeCategory.CONFIG: 'config'>, 'text/xml': <FileTypeCategory.CONFIG: 'config'>, 'text/yaml': <FileTypeCategory.CONFIG: 'config'>, 'video/': <FileTypeCategory.VIDEO: 'video'>}¶
-
detect_file_type(file_path: pathlib.Path, strip_prefix: str = '', use_magic=False) → snapm.fsdiff.filetypes.FileTypeInfo[source]¶ Detect comprehensive file type information, optionally using python-magic for MIME type detection.
- Parameters
file_path (
Path.) – The path to the file to inspect.strip_prefix (
str) – An optional prefix (mount root) to strip from thefile_pathwhen guessing file types.
- Returns
File type information for
file_path.- Return type
FileTypeInfo
-
-
class
snapm.fsdiff.filetypes.FileTypeInfo(mime_type: str, description: str, category: snapm.fsdiff.filetypes.FileTypeCategory, encoding: Union[None, str] = None)[source]¶ Bases:
objectClass representing file type information and encoding.
-
TEXT_DOCUMENTS= ('application/rtf', 'application/x-lyx')¶
-
__init__(mime_type: str, description: str, category: snapm.fsdiff.filetypes.FileTypeCategory, encoding: Union[None, str] = None)[source]¶ Initialise a new
FileTypeInfoobject.- Parameters
mime_type (
str) – The detected MIME type.description (
str) – Type description returned by magic.category (
FileTypeCategory) – File type category.encoding (
Optional[str]) – Optional file encoding.
-
-
snapm.fsdiff.filetypes._generic_guess_file(file_path: pathlib.Path, extension_map: Dict[str, Tuple[str, str]], filename_map: Dict[str, Tuple[str, str]], encoding: str) → Optional[Tuple[str, str, str]][source]¶ Attempt to guess a file’s MIME type and description based on the file name and extension.
- Parameters
file_path (
Path) – APathinstance containing the file path to check.extension_map (
Dict[str, Tuple[str, str]]) – A map of “.extension”: (mime_type, description) tuples to use.filename_map – A map of “filename”: (mime_type, description) tuples to use.
- Returns
A 3-tuple containing (mime_type, description, encoding) if the type could be guessed or
Noneotherwise.- Return type
Optional[Tuple[str, str, str]]
-
snapm.fsdiff.filetypes._guess_binary_file(file_path: pathlib.Path) → Optional[Tuple[str, str, str]][source]¶ Attempt to guess a binary file’s MIME type and description based on the file name and extension.
- Parameters
file_path (
Path) – APathinstance containing the file path to check.- Returns
A 3-tuple containing (mime_type, description, encoding) if the type could be guessed or
Noneotherwise.- Return type
Optional[Tuple[str, str, str]]
-
snapm.fsdiff.filetypes._guess_file(file_path: pathlib.Path) → Tuple[str, str, str][source]¶ Attempt to guess a file’s MIME type and description based on the file name and extension.
- Parameters
file_path (
Path) – APathinstance containing the file path to check.- Returns
A 3-tuple containing (mime_type, description, encoding).
- Return type
Tuple[str, str, str]
-
snapm.fsdiff.filetypes._guess_text_file(file_path: pathlib.Path) → Optional[Tuple[str, str, str]][source]¶ Attempt to guess a text file’s MIME type and description based on the file name and extension.
- Parameters
file_path (
Path) – APathinstance containing the file path to check.- Returns
A 3-tuple containing (mime_type, description, encoding) if the type could be guessed or
Noneotherwise.- Return type
Optional[Tuple[str, str, str]]
-
snapm.fsdiff.filetypes._is_binary_log(file_path: pathlib.Path) → bool[source]¶ Determine based on file name pattern match whether
file_pathrefers to a log file that normally contains binary data.- Parameters
file_path (
Path) – The path to test.- Returns
Trueiffile_pathis likely a binary log, orFalseotherwise.- Return type
bool
snapm.fsdiff.fsdiffer module¶
Top-level fsdiff interface.
-
class
snapm.fsdiff.fsdiffer.FsDiffer(manager: Manager, options: Optional[snapm.fsdiff.options.DiffOptions] = None, cache: bool = True, cache_expires: int = - 1, color: str = 'auto', term_control: Optional[snapm.progress.TermControl] = None)[source]¶ Bases:
objectTop-level interface for generating file system comparisons.
-
__init__(manager: Manager, options: Optional[snapm.fsdiff.options.DiffOptions] = None, cache: bool = True, cache_expires: int = - 1, color: str = 'auto', term_control: Optional[snapm.progress.TermControl] = None)[source]¶ Initialise a new
FsDifferto compute file system differences.- Parameters
manager (
Manager) – The manager context for snapshot operations (used by future methods).options (
DiffOptions) – Options to control thisFsDifferinstance.cache (
bool) – Use diff cache if available.cache_expires (
int) – Cache expiry in seconds. Use 0 to disable cache expiry or -1 to use the cache default (15m).color (
str) – A string to control color tree rendering: “auto”, “always”, or “never”.term_control (
Optional[TermControl]) – An optionalTermControlinstance to use for formatting. The supplied instance overrides anycolorargument if set.
-
compare_roots(mount_a: Mount, mount_b: Mount) → snapm.fsdiff.engine.FsDiffResults[source]¶ Compare two mounted snapshot sets and return diff results.
- Parameters
mount_a (
Mount) – The first (left hand) mount to compare.mount_b (
Mount) – The second (right hand) mount to compare.
- Returns
The diff results for the comparison.
- Return type
FsDiffResults
-
manager: Manager¶ Manager context for snapshot operations (used by future methods)
-
-
snapm.fsdiff.fsdiffer._MAX_RSS_FRACTION= 0.333¶ Maximum fraction of memory used to attempt diffing after building trees
-
snapm.fsdiff.fsdiffer._should_diff(options: snapm.fsdiff.options.DiffOptions) → bool[source]¶ Determine whether it is safe to attempt computing the diff given system memory constraints and current state.
- Parameters
options (
DiffOptions) – The effective options for this run.- Returns
Trueif diffing should be attempted orFalseotherwise.- Return type
bool
snapm.fsdiff.options module¶
File system diff options and categories.
-
class
snapm.fsdiff.options.DiffCategories(value)[source]¶ Bases:
enum.EnumEnum for categories of difference based on type or file system location.
-
APPLICATION= 'application'¶
-
CRITICAL_SYSTEM= 'critical_system'¶
-
LOG_FILES= 'log_files'¶
-
PACKAGE_MANAGEMENT= 'package_mgmt'¶
-
TEMPORARY= 'temporary'¶
-
USER_DATA= 'user_data'¶
-
-
class
snapm.fsdiff.options.DiffOptions(ignore_timestamps: bool = False, ignore_permissions: bool = False, ignore_ownership: bool = False, content_only: bool = False, include_system_dirs: bool = False, include_content_diffs: bool = True, use_magic_file_type: bool = False, follow_symlinks: bool = False, max_file_size: int = 0, max_content_diff_size: int = 1048576, max_content_hash_size: int = 1048576, file_patterns: Tuple[str, ...] = <factory>, exclude_patterns: Tuple[str, ...] = <factory>, from_path: Optional[Union[str, Tuple[str]]] = ('/', ), quiet: bool = False, no_mem_check: bool = False)[source]¶ Bases:
objectFile system comparison options.
-
__init__(ignore_timestamps: bool = False, ignore_permissions: bool = False, ignore_ownership: bool = False, content_only: bool = False, include_system_dirs: bool = False, include_content_diffs: bool = True, use_magic_file_type: bool = False, follow_symlinks: bool = False, max_file_size: int = 0, max_content_diff_size: int = 1048576, max_content_hash_size: int = 1048576, file_patterns: Tuple[str, ...] = <factory>, exclude_patterns: Tuple[str, ...] = <factory>, from_path: Optional[Union[str, Tuple[str]]] = ('/', ), quiet: bool = False, no_mem_check: bool = False) → None¶ Initialize self. See help(type(self)) for accurate signature.
-
__repr__()¶ Return repr(self).
-
__str__()[source]¶ Return a human readable string representation of this
DiffOptionsinstance.- Returns
A human readable string.
- Return type
str
-
content_only: bool = False¶ Only consider content changes
-
exclude_patterns: Tuple[str, …]¶ File patterns to exclude (glob notation)
-
file_patterns: Tuple[str, …]¶ File patterns to include (glob notation)
-
follow_symlinks: bool = False¶ Follow symlinks when walking file system trees
-
classmethod
from_cmd_args(cmd_args: argparse.Namespace) → snapm.fsdiff.options.DiffOptions[source]¶ Initialise DiffOptions from command line arguments.
Construct a new
DiffOptionsobject from the command line arguments incmd_args.- Parameters
cmd_args (
Namespace) – The command line selection arguments.- Returns
A new
DiffOptionsinstance- Return type
DiffOptions
-
from_path: Optional[Union[str, Tuple[str]]] = ('/',)¶ Start path(s) for file system comparison
-
ignore_ownership: bool = False¶ Ignore ownership in diff comparisons
-
ignore_permissions: bool = False¶ Ignore permissions in diff comparisons
-
ignore_timestamps: bool = False¶ Ignore timestamps in diff comparisons
-
include_content_diffs: bool = True¶ Generate content diffs for detected file modifications
-
include_system_dirs: bool = False¶ Include system directories in diff comparisons
-
max_content_diff_size: int = 1048576¶ Maximum size for generating content diffs
-
max_content_hash_size: int = 1048576¶ Maximum file size for generating content hashes
-
max_file_size: int = 0¶ Maximum file size for diff comparisons
-
no_mem_check: bool = False¶ Disable RSS memory pressure safety checks
-
quiet: bool = False¶ Do not output progress or status updates
-
use_magic_file_type: bool = False¶ Generate file type information using magic
-
snapm.fsdiff.treewalk module¶
Tree walking support for fsdiff.
-
class
snapm.fsdiff.treewalk.FsEntry(path: str, strip_prefix: str, stat_info: os.stat_result, content_hash: Union[None, str] = None, file_type_info: Optional[snapm.fsdiff.filetypes.FileTypeInfo] = None)[source]¶ Bases:
objectRepresentation of a single file system entry for comparison.
-
__init__(path: str, strip_prefix: str, stat_info: os.stat_result, content_hash: Union[None, str] = None, file_type_info: Optional[snapm.fsdiff.filetypes.FileTypeInfo] = None)[source]¶ Initialise a new
FsEntryobject.- Parameters
path (
str) – The full path to thisFsEntryrepresents.strip_prefix (
str) – An optional leading path prefix (mount root) to strip frompathbefore storing.stat_info (
os.stat_result) – Anos.stat_resultfor thisFsEntry.content_hash (
str) – A hash of the content of thisFsEntry.file_type_info (
FileTypeInfo) – AFileTypeInfoobject for thisFsEntry.
-
__str__()[source]¶ Return a string representation of this
FsEntryobject.- Returns
A human readable representation of this
FsEntry.- Return type
str
-
broken_symlink¶ Not a broken symlink
-
content_hash: Optional[str]¶ Calculated content hash or
Noneif not available.
-
file_type_info¶ An optional instance of
FileTypeInfodescribing this path.
-
full_path: pathlib.Path¶ The full path from the host perspective
-
gid: int¶ File group returned by
stat()
-
property
is_block¶ True if this
FsEntryis a block special file.- Returns
Trueif thisFsEntrycorresponds to a block special file orFalseotherwise.- Return type
bool
-
property
is_char¶ True if this
FsEntryis a character special file.- Returns
Trueif thisFsEntrycorresponds to a character special file orFalseotherwise.- Return type
bool
-
property
is_dir¶ True if this
FsEntryis a directory.- Returns
Trueif thisFsEntrycorresponds to a directory orFalseotherwise.- Return type
bool
-
property
is_fifo¶ True if this
FsEntryis a FIFO special file.- Returns
Trueif thisFsEntrycorresponds to a FIFO special file orFalseotherwise.- Return type
bool
-
property
is_file¶ True if this
FsEntryis a regular file.- Returns
Trueif thisFsEntrycorresponds to a regular file orFalseotherwise.- Return type
bool
-
property
is_sock¶ True if this
FsEntryis a socket.- Returns
Trueif thisFsEntrycorresponds to a socket orFalseotherwise.- Return type
bool
-
property
is_symlink¶ True if this
FsEntryis a symlink.- Returns
Trueif thisFsEntrycorresponds to a symlink orFalseotherwise.- Return type
bool
-
property
is_text_like¶ True if this
FsEntryis a text-like file.- Returns
Trueif thisFsEntrycorresponds to a text-like file orFalseotherwise.- Return type
bool
-
mode: int¶ File mode returned by
stat()
-
mtime: float¶ File modification time returned by
stat()
-
path: pathlib.Path¶ The path relative to this tree’s mount point
-
size: int¶ File size returned by
stat()
-
stat: os.stat_result¶ An
os.stat_resultfor this path
-
symlink_target¶ The symbolic link target:
Nonefor non-symlinks
-
to_dict() → Dict[str, Any][source]¶ Convert this
FsEntryobject into a dictionary representation suitable for encoding as JSON.- Returns
A dictionary mapping this instance’s keys to values.
- Return type
Dict[str, Any]
-
property
type_desc¶ Return a string description of the entry type: “file”, “dir”, or “symlink”.
- Returns
A string description of the entry type.
- Return type
str
-
uid: int¶ File owner returned by
stat()
-
xattrs: Dict[str, bytes]¶ Extended attributes as
Dict[str, bytes]
-
-
class
snapm.fsdiff.treewalk.TreeWalker(options, hash_algorithm: str = 'sha256')[source]¶ Bases:
objectSimple file system tree walker for comparisons.
-
__init__(options, hash_algorithm: str = 'sha256')[source]¶ Initialise a new
TreeWalkerobject.- Parameters
options (
DiffOptions) – Options to control thisTreeWalkerinstance.hash_algorithm (
str) – A string describing the hash algorithm to be used for thisTreeWalkerinstance.
-
_calculate_content_hash(file_path: str, strip_prefix: str = '') → str[source]¶ Calculate content hash for regular files
- Parameters
file_path (
str) – The path to the file to hash.strip_prefix (
str) – An optional leading path prefix to strip from stored path values.
- Returns
A string representation of the hash of the file content using the configured hash algorithm.
- Return type
str
-
_process_dir(dir_path: str, dir_stat: os.stat_result, strip_prefix: str) → snapm.fsdiff.treewalk.FsEntry[source]¶ Process a single directory at
dir_pathwith stat datadir_stat.- Parameters
dir_path (
str) – The path to examine.dir_stat (
os.stat_result) –os.stat()result fordir_path.
- Returns
A new
FsEntryrepresenting the directory.- Return type
FsEntry
-
_process_file(file_path: str, file_stat: os.stat_result, strip_prefix: str) → snapm.fsdiff.treewalk.FsEntry[source]¶ Process a single file at
file_pathwith stat datafile_stat.- Parameters
file_path (
str) – The path to examine.file_stat (
os.stat_result) –os.stat()result forfile_path.
- Returns
A new
FsEntryrepresenting the file.- Return type
FsEntry
-
walk_tree(mount: Mount, strip_prefix: str = '', quiet: bool = False, term_control: Optional[snapm.progress.TermControl] = None) → Dict[str, snapm.fsdiff.treewalk.FsEntry][source]¶ Walk filesystem tree starting from mount.root and return indexed entries.
- Parameters
mount (
snapm.manager._mounts.Mount) – Asnapm.manager._mounts.Mountobject representing the file system to walk.strip_prefix (
str) – An optional leading path prefix to strip from stored path values.quiet (
bool) – Suppress progress output.term_control (
Optional[TermControl]) – Optional pre-initialised terminal control object.
- Returns
A dictionary mapping path strings to
FsEntryobjects.- Return type
Dict[str, FsEntry]
-
-
snapm.fsdiff.treewalk._ALWAYS_EXCLUDE_PATTERNS= ('*/proc/kcore', '*/proc/kmsg', '*/proc/*/mem', '*/proc/*/pagemap', '*/proc/*/fd/*', '*/proc/*/task/*/mem', '*/proc/*/clear_refs', '*/proc/sys/fs/binfmt_misc/register', '*/proc/sys/net/ipv*/route/flush', '*/proc/sysrq-trigger', '*/proc/acpi/event', '/dev/zero', '/dev/full', '/dev/random', '/dev/urandom', '/dev/kmsg', '/dev/mem', '/dev/kmem', '/dev/port', '/dev/nvram', '/dev/console', '/dev/tty*', '/dev/pts/*', '/dev/ptmx', '/dev/input/*', '/dev/uinput', '/dev/watchdog*', '/dev/st*', '/dev/nst*', '*/sys/kernel/debug/*', '*/sys/kernel/tracing/trace_pipe', '*/sys/kernel/tracing/*/*/*_raw', '*/sys/kernel/tracing/*/*/trace_pipe', '*/sys/fs/cgroup/*', '*/sys/*/power/autosuspend_delay_ms', '*/sys/devices/pci*/rescan', '*/sys/*/bind', '*/sys/*/unbind', '*/sys/*/uevent')¶ Paths that are always excluded, no matter what the user says.
-
snapm.fsdiff.treewalk._EXCLUDE_SYSTEM_DIRS= ('/proc/*', '/sys/*', '/dev/*', '/tmp/*', '/run/*', '/var/run/*', '/var/lock/*')¶ Default system directories to exclude
-
snapm.fsdiff.treewalk._NO_CHUNK_PATHS= ('/proc/sys/fs/binfmt_misc/*', '/proc/sys/net/ipv*/conf/*', '/proc/irq/*/*', '/sys/*', '/dev/*')¶ Paths where we should avoid trying to read content in chunks.