Access a Cryptomator V8 vault with pure Python
Project description
pycryptomator
A Python 3 package to access a Cryptomator V8 vault and carry on some useful operations.
usage: pycryptomator [-h] [--init] [--print-keys [{a85,b64,words}]] [--master-keys PRIMARY_KEY HMAC_KEY]
[--password PASSWORD] [--change-password]
vault_name
Access to a Cryptomator V8 vault
positional arguments:
vault_name Location of the existing Cryptomator V8 vault to open
options:
-h, --help show this help message and exit
--init Initialize a new vault in an empty directory
--print-keys [{a85,b64,words}]
Print the raw master keys as a list of English words for Cryptomator (default), in ASCII85
(a85) or BASE64 (b64) format
--master-keys PRIMARY_KEY HMAC_KEY
Primary and HMAC master keys in ASCII85 or BASE64 format, or - - to read a words list from
standard input
--password PASSWORD Password to unlock master keys stored in config file
--change-password Change the password required to open the vault
Passing a couple options, you can show you master keys or recover them in case configuration files are corrupted:
--print-keys
shows the decrypted primary and hmac master key in ASCII85
or BASE64 form, or as a list of English words like Cryptomator itself, to
annotate them in a safe place for recovering purposes.
--master-keys
grants access to the vault even in case of lost configuration
files vault.cryptomator
and/or masterkey.cryptomator
, provided the master
keys as ASCII85 or BASE64 strings; - -
can be used to read the words list
from standard input.
After the vault_name
, you can specify some useful operations like:
cd change vault's current directory
ls list unecrypted vault contents (with size and time)
mkdir create a new directory/tree in the vault
mv move or rename files and directories
ln create a symbolic link
rm erase files or directories
decrypt decrypt a file or directory from the vault's virtual filesystem into a given destination
encrypt encrypt a file or directory
alias show the real pathname linked to a virtual one
backup backup the Directory IDs (required to decrypt names) in a ZIP file
If no operation is specified, an interactive shell is launched on open vault. It can do transparent wildcards expansion (*
and ?
only).
Functionality was tested in Windows 11 and Ubuntu 22.04 LTS Linux (under Windows WSL).
It's pure Python 3, with pycryptodome addon.
MIT licensed. Absolutely no warranty!
Internal commands
*
and ?
wildcards can be specified on command line to enable automatic shell expansion.
alias <pathname>
show the real base64 (encrypted and obfuscated) pathname corresponding to the
vault's pathname
backup <archive.zip>
make in archive.zip a backup of all the directory id files dir.c9r
encountered in the vault tree: they are required to reconstruct original file
names
cd <directory>
make the specified vault's directory the current one in the pycryptomator
internal shell
decrypt [-fmF] <virtual_pathname_source1...> <real_pathname_destination>
decrypt <virtual_pathname_source> -
decrypt one or more files and/or directories to the specified destination in the
real file system.
-f
forces to overwrite existing files, -m
moves (i.e. deletes) the source
files after decryption, -F
replicates the full command line path of source
in destination (by default only filenames are copied).
With -
as destination, a file is decrypted and printed to standard output.
encrypt [-fmF] <real_pathname_source1...> <virtual_pathname_destination>
encrypt one or more files and/or directories to the specified destination.
If multiple sources are specified, the destination directory will be created
if not existent.
-f
forces to overwrite existing files, -m
moves (i.e. deletes) the source
files after encryption, -F
replicates the full command line path of source
in destination (by default only filenames are copied).
ln [-old] <target> <link>
make a symbolic link to a target file or directory in the vault.
It does not check for target existence.
An absolute target should be avoided, since it prevents portability
(i.e. to Windows).
When targeting a directory with -old
, its dir.c9r file is copied to enable
compatibility with old vault formats (i.e. with current Cryptomator for Android
v. 1.10.3).
ls [-b] [-r] [-s NSDE-!] <virtual_path1> [...<virtual_pathN>]
list files and directories with minimal informations like DOS DIR (type/size,
write time, name, symbolic link target).
-b
prints bare names
-r
traverses specified directories recursively
-s
sorts results by one or more criteria: N
ame, S
ize, D
ate, E
xtension
(a.k.a. file type), -
sorts in reverse order and !
puts directories first.
mkdir [-R] <dir1> [...<dirN>]
make one or more directories or directory trees (i.e. intermediate directories
get created) in the vault or in the real file system if -R
is specified.
mv <source> [<source2>...<sourceN>] <destination>
rename or move files and directories. If more files or directories are specified,
destination must be an existing directory and objects are moved inside it;
else, if destination does not exist, it renames the file or directory.
rm [-f] <file1|dir1> [...<fileN|dirN>]
remove files and directories. Root directory is protected against accidental
deletion. If a directory is not empty, -f
switch is required to force its
removal.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pycryptomator-1.14.tar.gz
.
File metadata
- Download URL: pycryptomator-1.14.tar.gz
- Upload date:
- Size: 40.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b07bb61e7d4d43ae6d0e6d5180b3dbaccc302c3ee41f1f07b0cbd1759260919d |
|
MD5 | 82802c16c213f5eda94636a8297322be |
|
BLAKE2b-256 | 08081299625d410bd19e798f35b373fae40dd5635eb195008c83a9aa37177ccb |
Provenance
The following attestation bundles were made for pycryptomator-1.14.tar.gz
:
Publisher:
python-publish.yml
on maxpat78/pycryptomator
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pycryptomator-1.14.tar.gz
- Subject digest:
b07bb61e7d4d43ae6d0e6d5180b3dbaccc302c3ee41f1f07b0cbd1759260919d
- Sigstore transparency entry: 146983422
- Sigstore integration time:
- Predicate type:
File details
Details for the file pycryptomator-1.14-py3-none-any.whl
.
File metadata
- Download URL: pycryptomator-1.14-py3-none-any.whl
- Upload date:
- Size: 39.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 41027f9b69d869c4f1e7b0ac20990ed901d73193afcd812afe7b2462d75aa652 |
|
MD5 | ebd02929562924f30332c35c26bb52f6 |
|
BLAKE2b-256 | 928bd8961638ef013a013bbec0644fc51e17496d742e921fd117ef7136f76f5c |
Provenance
The following attestation bundles were made for pycryptomator-1.14-py3-none-any.whl
:
Publisher:
python-publish.yml
on maxpat78/pycryptomator
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pycryptomator-1.14-py3-none-any.whl
- Subject digest:
41027f9b69d869c4f1e7b0ac20990ed901d73193afcd812afe7b2462d75aa652
- Sigstore transparency entry: 146983424
- Sigstore integration time:
- Predicate type: