Encrypts and decrypts private information
Project description
SECRETS GUARD
Encrypts and decrypts private information, written in Python3.
DESCRIPTION
Secrets Guard is a tool for encrypt and decrypt any kind of information.
The idea is create a store with a given model and then insert 'secrets' inside it.
It's similar the Linux tool pass
, but uses AES instead of GPG and allows to create general purpose store containing any kind of info, not only passwords.
REQUIREMENTS
Requires at least Python 3.
Requires 'pycryptodomex' library.
INSTALLATION
pip3 install secrets-guard
The script can be used with python3 -m secrets_guard ...
.
Along with the installation via pip, a script called secrets
will be
installed, which is a shortcut for python3 -m secrets_guard
.
USAGE
Each command works either in interactive or batch mode, depending on the
provided arguments.
For example, if the key
is not provided with --key
it will be asked to the user.
Global commands
list
For list all the store within a path (the default if not specified with --path
)
the list
command can be used.
secrets list
Store commands
create
First of all, a store should be created using the command create
.
For example, for create a basic password store with the name 'password':
secrets create password --fields Site Account Password Other
destroy
A store can be destroyed with destroy
.
secrets destroy password
key
Changes the key of the store.
secrets key password newkey
clear
Removes all the secrets from a store.
secrets clear password
show
The entire content of a store can be seen using show
.
secrets show password
grep
For search between the secrets' fields for a specific word (or regular expression) the command grep
can be used.
secrets grep password MyPass
secrets grep password "^My.*word"
Secret commands
add
A secret can be added to an existent store using add
as follows:
secrets add password --data Site="Megavideo",Account="me@gmail.com",Password="MyPassword"
remove
A secret can be removed from a store using remove
.
The ID of the secret to remove must be specified (it can be retrieved with grep
or show
).
secrets remove password 12
modify
The fields of a secret can be changed using modify
as follows:
secrets modify password 11 --data Password="MyNewPassword"
GIT Commands
For keep the local repository synchronized with a remote GIT repository, the following commands can be used. (The repository should already be initialized and configured properly).
The whole repository can be pushed with push
:
secrets push --message "Added Google Drive password"
And can be pulled with pull
:
secrets pull
HELP
For more details about the commands, use help
:
NAME
secrets - encrypt and decrypt data
SYNOPSIS
secrets <COMMAND> [COMMAND_OPTIONS] [GENERAL_OPTIONS]
DESCRIPTION
Stores and retrieves encrypted data to/from files.
Each command can be used either in batch or interactive mode;
each mandatory but not specified argument will be required interactively.
One of the following command must be specified:
GLOBAL COMMANDS
list [--path <PATH>]
List the names of the stores found at the path specified
by --path (or at the default one if not specified).
e.g. secrets list
STORE COMMANDS
create [<STORE_NAME>] [--fields FIELDS] [--pull] [--push] [--sync] [--path <PATH>] [--key <STORE_KEY>]
Creates a new store at the given path using the given key.
The FIELDS must be expressed as a comma separated list of field names.
Furthermore some attributes can be expressed for the fields by appending
"+<attr_1><attr_2>..." after the field name.
The available attributes are
1) h: hidden (the user input is not shown)
2) m: mandatory (the field must contain a non empty string)
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
e.g. secrets create password --fields Site,Account,Password,Other
e.g. secrets create password --fields Site+m,Account+m,Password+mh,Other
destroy [<STORE_NAME>] [--pull] [--push] [--sync] [--path <PATH>]
Destroys the store at the given path.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
e.g. secrets destroy password
key [<STORE_NAME>] [<NEW_STORE_KEY>] [--pull] [--push] [--path <PATH>] [--key <STORE_KEY>]
Changes the key of the store from STORE_KEY to NEW_STORE_KEY.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
e.g. secrets key newkey
clear [<STORE_NAME>] [--pull] [--push] [--sync] [--path <PATH>] [--key <STORE_KEY>]
Clears the content (all the secrets) of a store.
The model is left unchanged.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
show [<STORE_NAME>] [--fields FIELDS] [--when] [--[r]sort SORT_FIELD] [--no-table] [--pull] [--path <PATH>] [--key <STORE_KEY>]
Decrypts and shows the content of an entire store.
If --fields is is given, FIELDS specify the fields to show and these must
be expressed as a comma separated list of field names.
The --when parameter shows also temporal info (add/last modify date).
The --sort and --rsort can be used for sort the secrets alphabetically by FIELD.
If --pull is given, 'git pull' is performed before performing the action.
e.g. secrets show password
e.g. secrets show password --sort Added
e.g. secrets show password --sort Modified
grep [<STORE_NAME>] [<SEARCH_PATTERN>] [--fields FIELDS] [--when] [--[r]sort SORT_FIELD] [--no-table] [--no-color] [--pull] [--path <PATH>] [--key <STORE_KEY>]
Performs a regular expression search between the data of the store.
The SEARCH_PATTERN can be any valid regular expression.
The matches will be highlighted unless --no-color is specified.
If --fields is is given, FIELDS specify the fields to show and these must
be expressed as a comma separated list of field names.
The --when parameter shows also temporal info (add/last modify date)
The --sort and --rsort can be used for sort the secrets alphabetically by SORT_FIELD.
If --pull is given, 'git pull' is performed before performing the action.
e.g. secrets grep password MyPass
e.g. secrets grep password "^My.*word" --fields Name,Other
SECRET COMMANDS
add [<STORE_NAME>] [--data DATA] [--pull] [--push] [--sync] [--path <PATH>] [--key <STORE_KEY>]
Inserts a new secret into a store.
The DATA must be expressed as a key=value comma separated list where the
key should be a field of the store.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
e.g. secrets add password --data Site="Megavideo",Account="me@gmail.com",Password="MyPassword"
remove [<STORE_NAME>] [<SECRET_IDS>*] [--pull] [--push] [--sync] [--path <PATH>] [--key <STORE_KEY>]
Removes the secret(s) with the given SECRET_IDS from the store.
The SECRET_IDS should be a comma separated list of IDs retrieved
using the secrets grep or the show command.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
e.g. secrets remove password 12
e.g. secrets remove password 12,14,15,7 11
modify [<STORE_NAME>] [<SECRET_ID>] [--data DATA] [--pull] [--push] [--sync] [--path <PATH>] [--key <STORE_KEY>]
Modifies the secret with the given SECRET_ID using the given DATA.
The DATA must be expressed as a key=value list.
If --pull is given, 'git pull' is performed before performing the action.
If --push is given, 'git push' is performed after the action has been successfully performed.
The option --sync acts as '--pull --push'.
e.g. secrets modify password 11 --data Password="MyNewPassword"
GIT COMMANDS
push [--message <COMMIT_MESSAGE>] [--path <PATH>]
Commits and pushes to the remote git repository.
Actually performs "git add ." , "git commit -m 'COMMIT_MESSAGE'" and
"git push" on the given path.
Note that the action is related to the whole repository,
not a particular store.
If the COMMIT_MESSAGE is not specified, a default commit message
will be created.
The credentials might be required by the the invoked git push routine.
e.g. secrets push
e.g. secrets push
e.g. secrets push --message "Added Google password"
Pull from the remote git branch.
Note that the action is related to the whole repository,
not a particular store.
e.g. secrets pull
GLOBAL OPTIONS
--help
Shows this help message.
--version
Shows the version number.
--verbose
Prints debug statements.
--no-keyring
Do not use the keyring for retrieve the password.
By default a password used for open a store is cached in the keyring
for further uses.
LICENSE
Secrets Guard is MIT licensed.
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 Distributions
Built Distribution
File details
Details for the file secrets_guard-0.19-py3-none-any.whl
.
File metadata
- Download URL: secrets_guard-0.19-py3-none-any.whl
- Upload date:
- Size: 13.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fbb03f413d06e40486b4bb027bbf5464316294275b394c26a115be5365452cda |
|
MD5 | c1dd3e22d8b2e1987cee4b927b3e24f9 |
|
BLAKE2b-256 | c8e360486eaac45a9a05cf67024dfd6fe71426abc5264bac1c90ad70ed094059 |