Submodule cli
derivepassphrase.cli
¶
Command-line interface for derivepassphrase.
OptionGroupOption
¶
OptionGroupOption(*args: Any, **kwargs: Any)
Bases: Option
A click.Option
with an associated group name and group epilog.
Used by derivepassphrase.cli.CommandWithHelpGroups
to print
help sections. Each subclass contains its own group name and
epilog.
Attributes:
Name | Type | Description |
---|---|---|
option_group_name |
str
|
The name of the option group. Used as a heading on the help text for options in this section. |
epilog |
str
|
An epilog to print after listing the options in this section. |
CommandWithHelpGroups
¶
Bases: Command
A click.Command
with support for help/option groups.
Inspired by a comment on pallets/click#373
, and
further modified to support group epilogs.
format_options
¶
format_options(
ctx: click.Context, formatter: click.HelpFormatter
) -> None
Format options on the help listing, grouped into sections.
This is a callback for click.Command.get_help
that
implements the --help
listing, by calling appropriate methods
of the formatter
. We list all options (like the base
implementation), but grouped into sections according to the
concrete click.Option
subclass being used. If the option
is an instance of some subclass X
of
derivepassphrase.cli.OptionGroupOption
, then the section
heading and the epilog are taken from X.option_group_name
and
X.epilog
; otherwise, the section heading is “Options” (or
“Other options” if there are other option groups) and the epilog
is empty.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
ctx |
Context
|
The click context. |
required |
formatter |
HelpFormatter
|
The formatter for the |
required |
PasswordGenerationOption
¶
PasswordGenerationOption(*args: Any, **kwargs: Any)
ConfigurationOption
¶
ConfigurationOption(*args: Any, **kwargs: Any)
StorageManagementOption
¶
StorageManagementOption(*args: Any, **kwargs: Any)
derivepassphrase
¶
derivepassphrase(*, subcommand_args: list[str]) -> None
Derive a strong passphrase, deterministically, from a master secret.
Using a master secret, derive a passphrase for a named service, subject to constraints e.g. on passphrase length, allowed characters, etc. The exact derivation depends on the selected derivation scheme. For each scheme, it is computationally infeasible to discern the master secret from the derived passphrase. The derivations are also deterministic, given the same inputs, thus the resulting passphrases need not be stored explicitly. The service name and constraints themselves also generally need not be kept secret, depending on the scheme.
The currently implemented subcommands are “vault” (for the scheme
used by vault) and “export” (for exporting foreign configuration
data). See the respective --help
output for instructions. If no
subcommand is given, we default to “vault”.
Deprecation notice: Defaulting to “vault” is deprecated. Starting in v1.0, the subcommand must be specified explicitly.
This is a click
-powered command-line interface function,
and not intended for programmatic use. Call with arguments
['--help']
to see full documentation of the interface. (See also
click.testing.CliRunner
for controlled, programmatic
invocation.)
derivepassphrase_export
¶
derivepassphrase_export(
*, subcommand_args: list[str]
) -> None
Export a foreign configuration to standard output.
Read a foreign system configuration, extract all information from it, and export the resulting configuration to standard output.
The only available subcommand is “vault”, which implements the vault-native configuration scheme. If no subcommand is given, we default to “vault”.
Deprecation notice: Defaulting to “vault” is deprecated. Starting in v1.0, the subcommand must be specified explicitly.
This is a click
-powered command-line interface function,
and not intended for programmatic use. Call with arguments
['--help']
to see full documentation of the interface. (See also
click.testing.CliRunner
for controlled, programmatic
invocation.)
derivepassphrase_export_vault
¶
derivepassphrase_export_vault(
ctx: click.Context,
/,
*,
path: str | bytes | os.PathLike[str],
formats: Sequence[
Literal["v0.2", "v0.3", "storeroom"]
] = (),
key: str | bytes | None = None,
) -> None
Export a vault-native configuration to standard output.
Read the vault-native configuration at PATH, extract all information from it, and export the resulting configuration to standard output. Depending on the configuration format, PATH may either be a file or a directory. Supports the vault “v0.2”, “v0.3” and “storeroom” formats.
If PATH is explicitly given as VAULT_PATH
, then use the
VAULT_PATH
environment variable to determine the correct path.
(Use ./VAULT_PATH
or similar to indicate a file/directory actually
named VAULT_PATH
.)
derivepassphrase_vault
¶
derivepassphrase_vault(
ctx: click.Context,
/,
*,
service: str | None = None,
use_phrase: bool = False,
use_key: bool = False,
length: int | None = None,
repeat: int | None = None,
lower: int | None = None,
upper: int | None = None,
number: int | None = None,
space: int | None = None,
dash: int | None = None,
symbol: int | None = None,
edit_notes: bool = False,
store_config_only: bool = False,
delete_service_settings: bool = False,
delete_globals: bool = False,
clear_all_settings: bool = False,
export_settings: (
TextIO | pathlib.Path | os.PathLike[str] | None
) = None,
import_settings: (
TextIO | pathlib.Path | os.PathLike[str] | None
) = None,
) -> None
Derive a passphrase using the vault(1) derivation scheme.
Using a master passphrase or a master SSH key, derive a passphrase for SERVICE, subject to length, character and character repetition constraints. The derivation is cryptographically strong, meaning that even if a single passphrase is compromised, guessing the master passphrase or a different service’s passphrase is computationally infeasible. The derivation is also deterministic, given the same inputs, thus the resulting passphrase need not be stored explicitly. The service name and constraints themselves also need not be kept secret; the latter are usually stored in a world-readable file.
If operating on global settings, or importing/exporting settings, then SERVICE must be omitted. Otherwise it is required.
This is a click
-powered command-line interface function,
and not intended for programmatic use. Call with arguments
['--help']
to see full documentation of the interface. (See also
click.testing.CliRunner
for controlled, programmatic
invocation.)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
ctx |
Context
|
The |
required |
Other Parameters:
Name | Type | Description |
---|---|---|
service |
str | None
|
A service name. Required, unless operating on global settings or importing/exporting settings. |
use_phrase |
bool
|
Command-line argument |
use_key |
bool
|
Command-line argument |
length |
int | None
|
Command-line argument |
repeat |
int | None
|
Command-line argument |
lower |
int | None
|
Command-line argument |
upper |
int | None
|
Command-line argument |
number |
int | None
|
Command-line argument |
space |
int | None
|
Command-line argument |
dash |
int | None
|
Command-line argument |
symbol |
int | None
|
Command-line argument |
edit_notes |
bool
|
Command-line argument |
store_config_only |
bool
|
Command-line argument |
delete_service_settings |
bool
|
Command-line argument |
delete_globals |
bool
|
Command-line argument |
clear_all_settings |
bool
|
Command-line argument |
export_settings |
TextIO | Path | PathLike[str] | None
|
Command-line argument |
import_settings |
TextIO | Path | PathLike[str] | None
|
Command-line argument |