df1756fe1222e9bf01b9f256a8a212174c144876
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

1) # derivepassphrase-vault(1)
2) 
3) ## NAME
4) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

5) derivepassphrase-vault – derive a passphrase using the vault derivation scheme
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

6) 
7) ## SYNOPSIS
8) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

9) <pre>
10) <code><b>derivepassphrase vault</b> [--phrase | --key] [--length <var>n</var>] [--repeat <var>n</var>] [--lower <var>n</var>] [--upper <var>n</var>] [--number <var>n</var>] [--space <var>n</var>] [--dash <var>n</var>] [--symbol <var>n</var>] <var>SERVICE</var></code>
11) <code><b>derivepassphrase vault</b> {--phrase | --key | … | --symbol <var>n</var>} … --config [--unset <var>setting</var> …] [--overwrite-existing | --merge-existing] [<var>SERVICE</var>]</code>
12) <code><b>derivepassphrase vault</b> {--notes <var>SERVICE</var> | --delete <var>SERVICE</var> | --delete-globals | --clear}</code>
13) <code><b>derivepassphrase vault</b> [--export-as {json | sh}] {--import <var>PATH</var> | --export <var>PATH</var>}</code>
14) </pre>
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

15) 
16) ## DESCRIPTION
17) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

18) Using a master passphrase, derive a passphrase for <var>SERVICE</var>, subject to length, character and character repetition constraints, in a manner compatible with James Coglan's <i>vault</i>(1).
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

19) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

20) The derivation is <em>strong</em>: derived passphrases have as much entropy as permitted by the master passphrase and the passphrase constraints (whichever is more restrictive), and even if multiple derived passphrases are compromised, the master passphrase remains cryptographically difficult to discern from these compromised passphrases.
21) The derivation is also <em>deterministic</em>, given the same inputs, thus the resulting passphrase need not be stored explicitly.
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

22) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

23) The service name and constraints themselves also need not be kept secret; the latter are usually stored in a world-readable file to ease repeated entry of passphrase constraints.
24) 
25) In lieu of a master passphrase, a master SSH key can also be used if there is a reachable, running SSH agent currently holding this key and if the key type is supported.  (See ["SSH KEY SUITABILITY"](#ssh-key-suitability) and ["BUGS"](#bugs) below.)  This too is compatible with <i>vault</i>(1).
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

26) 
27) ## OPTIONS
28) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

29) ### Passphrase generation
30) 
31) The passphrase generation options can be divided into "passphrase source" options (`--phrase`, `--key`) and "passphrase constraint" options (all others).
32) The passphrase source options are mutually exclusive --- you may only specify one of them --- while the passphrase constraint options may be combined in any way.
33) The <var>SERVICE</var> is mandatory (see synopsis #1), unless the `--config` option is specified (see synopsis #2).
34) All character constraints refer to ASCII printable characters only (space (`U+0020`) to tilde (`U+007E`), excluding the grave accent (`U+0060`)).
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

35) 
36) <b>-p</b>, <b>-</b><b>-phrase</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

37) :   Prompt for a passphrase.
38) 
39)     See also ["Configuration"](#configuration) for how this interacts with a stored passphrase or SSH key.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

40) 
41) <b>-k</b>, <b>-</b><b>-key</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

42) :   Select an SSH key.
43) 
44)     An SSH agent such as OpenSSH’s <i>ssh-agent</i>(1) or PuTTY’s <i>pageant</i>(1) must be running and accessible, and have the desired key loaded.
45)     The SSH key must also be <i>suitable</i> for this purpose; see ["SSH KEY SUITABILITY"](#ssh-key-suitability) for details.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

46) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

47)     See also ["Configuration"](#configuration) for how this interacts with a stored passphrase or SSH key.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

48) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

49) <b>-l</b> <var>n</var>, <b>-</b><b>-length</b> <var>n</var>
50) :   Force the passphrase to have the length <var>n</var>.
51)     Defaults to the length <b>20</b> if not specified, or if explicitly specified as <code>0</code>.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

52) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

53) <b>-r</b> <var>n</var>, <b>-</b><b>-repeat</b> <var>n</var>
54) :   Permit only runs of up to <var>n</var> consecutive occurrences of the same character.
55)     Alternatively, forbid immediate additional repetitions of length <var>n</var> (or more) for any character in the derived passphrase.
56)     Setting <var>n</var> = `0` disables repetition constraints, which is the default.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

57) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

58) <b>-</b><b>-lower</b> <var>n</var>
59) :   Include at least <var>n</var> lowercase characters in the derived passphrase.
60)     Setting <var>n</var> = `0` forbids these characters entirely.
61)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

62) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

63) <b>-</b><b>-upper</b> <var>n</var>
64) :   Include at least <var>n</var> uppercase characters in the derived passphrase.
65)     Setting <var>n</var> = `0` forbids these characters entirely.
66)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

67) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

68) <b>-</b><b>-number</b> <var>n</var>
69) :   Include at least <var>n</var> digits in the derived passphrase.
70)     Setting <var>n</var> = `0` forbids these characters entirely.
71)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

72) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

73) <b>-</b><b>-space</b> <var>n</var>
74) :   Include at least <var>n</var> spaces in the derived passphrase.
75)     Setting <var>n</var> = `0` forbids these characters entirely.
76)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

77) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

78) <b>-</b><b>-dash</b> <var>n</var>
79) :   Include at least <var>n</var> "dashes" (`-` or `_`) in the derived passphrase.
80)     Setting <var>n</var> = `0` forbids these characters entirely.
81)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

82) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

83) <b>-</b><b>-symbol</b> <var>n</var>
84) :   Include at least <var>n</var> symbols (any of `!"#$%&'()*+,./:;<=>?@[\]^{|}~-_`) in the derived passphrase.
85)     Setting <var>n</var> = `0` forbids these characters entirely, effectively also implying `--dash 0`.
86)     The default is to not constrain the occurrences in any manner.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

87) 
88) ### Configuration
89) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

90) The configuration options directly modify the stored settings: default settings, known services, and service-specific settings.
91) They are mutually exclusive; you may only specify one of them.
92) The <var>SERVICE</var> is mandatory for `--notes` and `--delete`, optional for `--config`, and forbidden for `--delete-globals` and `--clear` (see synopsis #2 and synopsis #3).
93) 
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

94) <b>-n</b>, <b>-</b><b>-notes</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

95) :   Spawn an editor to edit notes for <var>SERVICE</var>.
96)     Use the `VISUAL` or `EDITOR` environment variables to configure the spawned editor.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

97) 
98) <b>-c</b>, <b>-</b><b>-config</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

99) :   Save the given settings for <var>SERVICE</var> (if given), or save the given settings as global default settings.
100) 
101)     See the ["Passphrase generation"](#passphrase-generation) and ["Compatibility and extension options"](#compatibility-and-extension-options) sections for other options compatible with `--config`.
102) 
103)     !!! danger
104) 
105)         Do **not** use the `--phrase` and `--config` options together.
106)         The configuration is assumed to *not contain sensitive contents*, and is *not encrypted*.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

107) 
108) <b>-x</b>, <b>-</b><b>-delete</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

109) :   Delete all stored settings for <var>SERVICE</var>.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

110) 
111) <b>-</b><b>-delete-globals</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

112) :   Delete all stored global default settings.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

113) 
114) <b>-X</b>, <b>-</b><b>-clear</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

115) :   Delete all stored settings.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

116) 
117) ### Storage management
118) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

119) The storage management options deal with importing and exporting the stored settings.
120) They are mutually exclusive; you may only specify one of them.
121) Using `-` as <var>PATH</var> for standard input/standard output is supported.
122) 
123) <b>-e</b> <var>PATH</var>, <b>-</b><b>-export</b> <var>PATH</var>
124) :   Export all saved settings into file <var>PATH</var>.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

125) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

126) <b>-i</b> <var>PATH</var>, <b>-</b><b>-import</b> <var>PATH</var>
127) :   Import saved settings from file <var>PATH</var>.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

128) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

129) ### Compatibility and extension options
130) 
131) By default, <b>derivepassphrase vault</b> behaves in a manner compatible with <i>vault</i>(1).
132) The compatibility and extension options modify the behavior to enable additional functionality, or specifically to force compatibility.
133) 
134) <i>vault</i>(1) supports none of these options, and behaves as if the option had not been given or had been left in its default state.
135) 
136) <b>-</b><b>-overwrite-existing</b> / <b>-</b><b>-merge-existing</b>
137) :   When importing a configuration via `--import`, or configuring the settings via `--config`, overwrite or merge (<em>default</em>) the existing configuration.
138) 
139)     If overwriting the configuration, then the whole configuration (for `--import`) or the respective section (service-specific or global, for `--config`), will be written from scratch.
140)     If merging, then each section (service-specific or global, for `--import`) or each singular setting (for `--config`) will be overwritten, but other unaffected settings/sections will not.
141) 
142)     (<i>vault</i>(1) behaves as if `--merge-existing` were always given.)
143) 
144) <b>-</b><b>-unset</b> <var>setting</var>
145) :   When configuring via `--config`, also unset the specified <var>setting</var>, where <var>setting</var> is one of the passphrase generation settings (<code>phrase</code>, <code>key</code>, <code>lower</code>, …).
146)     May be specified multiple times.
147)     Must not overlap with any of the settings being set afterwards.
148) 
149)     (vault(1) does not support this option.)
150) 
151) <b>-</b><b>-export-as</b> \{ <b>json</b> | <b>sh</b> \}
152) :   When exporting the configuration via `--export`, export as JSON (default) or as a shell script in <i>sh</i>(1) format.
153) 
154)     The JSON format is compatible with <i>vault</i>(1).
155)     For the shell script format, see the ["SHELL SCRIPT EXPORT FORMAT"](#shell-script-export-format) section for details.
156) 
157)     (vault(1) behaves as if `--export-as json` were always given.)
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

158) 
159) ### Other Options
160) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

161) <b>-</b><b>-version</b>
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

162) :   Show the version and exit.
163) 
164) <b>-h</b>, <b>-</b><b>-help</b>
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

165) :   Show a help message and exit.
166) 
167) ## SHELL SCRIPT EXPORT FORMAT
168) 
169) If the shell script export format is selected, the configuration will be exported as a POSIX <i>sh</i>(1) script, containing calls to <b>derivepassphrase vault</b> to reconstruct the current configuration from scratch.
170) The script assumes a conforming <i>sh</i>(1), with support for "here" documents.
171) 
172) !!! danger
173) 
174)     **Do not run these emitted shell scripts directly without double-checking their output first!**
175) 
176) ## SSH KEY SUITABILITY
177) 
178) An SSH key is <dfn>suitable</dfn> for use with <b>derivepassphrase vault</b> if the SSH agent guarantees that signatures produced with this key will be <em>deterministic</em>, given the same message to be signed.
179) This is a property specific to the key type, and sometimes the agent used:
180) 
181)   * RSA, Ed25519 and Ed448 keys are always suitable.
182)     OpenSSH’s <i>ssh-agent</i>(1) supports only these keys as suitable keys.
183) 
184)   * DSA and ECDSA keys are suitable if the SSH agent supports deterministic DSA signatures, e.g. by implementing RFC 6979.
185)     PuTTY’s <i>pageant</i>(1) supports this, in addition to the always-suitable keys mentioned above.
186) 
187) ## ENVIRONMENT
188) 
189) `VISUAL`, `EDITOR`
190) :   <b>derivepassphrase vault</b> uses this editor to edit service notes when called with `--notes`.
191)     `VISUAL` has higher precedence than `EDITOR`.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

192) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

193) `DERIVEPASSPHRASE_PATH`
194) :   <b>derivepassphrase</b> stores its configuration files and data in this directory.
195)     Defaults to `~/.derivepassphrase`.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

196) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

197) ## FILES
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

198) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

199) `$DERIVEPASSPHRASE_PATH/vault.json`
200) :   The stored configuration for <b>derivepassphrase vault</b>: the default passphrase generation settings, the known service names, and the service-specific settings.
201)     This file is <em>not</em> intended for the user to edit.
202) 
203) ## SECURITY
204) 
205) !!! danger
206) 
207)       * There is **no way** to retrieve the generated passphrases if the master passphrase, the SSH key, or the exact passphrase settings are lost, short of trying out all possible combinations.
208)         You are **strongly** advised to keep independent backups of the settings and the SSH key, if any.
209) 
210)       * The configuration is **not** encrypted, and you are **strongly** discouraged from using a stored passphrase.
211) 
212)       * You are **strongly** advised to avoid the (shell script) configuration export format if possible, and use the JSON format instead.
213)         If you *must* use the shell script format, then **always** validate the export before attempting to interpret or run it.
214) 
215) ## EXAMPLES
216) 
217) ??? example "`derivepassphrase vault --phrase email`"
218) 
219)     Prompt for a master passphrase, then generate a standard passphrase (length 20, no character or repetition constraints) for the "email" service.
220) 
221) ??? example "`derivepassphrase vault --key --upper 9 --lower 9 example.com`"
222) 
223)     Select an SSH key from the available suitable SSH keys in the running SSH agent, then generate a passphrase for the `example.com` service using the previously selected SSH key.
224)     The passphrase will have (standard) length 20, and at least nine characters will be uppercase characters and at least another nine characters will be lowercase characters.
225) 
226) ??? example "`derivepassphrase example.com vault --key --upper 9 --lower 9 --number 9`"
227) 
228)     Attempt to generate a passphrase as in the previous example.
229)     This example will <em>error out</em>, because the passphrase constraints require at least 27 characters and the standard passphrase length 20 cannot accomodate this.
230) 
231) ??? example "`derivepassphrase --config vault --key --upper 9 --lower 9 --space 2`"
232) 
233)     After selecting an SSH key, configure the default settings to use exactly nine uppercase characters, nine lowercase characters, and two spaces for each generated passphrase.
234)     (The specific service settings, or the command-line invocation, can still override these settings.)
235) 
236) ??? example "`derivepassphrase vault example.com`"
237) 
238)     Because of the previous setting, the generated passphrase for the `example.com` service will behave as if `--key --upper 9 --lower 9 --space 2` had been specified during invocation (with the SSH key already having been selected).
239)     In particular, it is neither necessary to specify `--phrase` or `--key` nor is it necessary to actually select an SSH key or to type in a master passphrase.
240) 
241) ## DIAGNOSTICS
242) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

243) The <b>derivepassphrase vault</b> utility exits 0 on success, and >0 if an error occurs.
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

244) 
Marco Ricci Extract translatable log me...

Marco Ricci authored 2 weeks ago

245) ### Fatal error messsages on standard error
246) 
247) (`%s` indicates a variable part of the message.)
248) 
249) ??? failure "`%s is mutually exclusive with %s.`"
250) 
251)     The two indicated options must not be used at the same time.
252) 
253) ??? failure "`%s requires a SERVICE or --config.`"
254) 
255)     Using the indicated passphrase generation option requires the <var>SERVICE</var> argument or the `--config` option.
256) 
257) ??? failure "`%s requires a SERVICE.`"
258) 
259)     Using the indicated option requires the <var>SERVICE</var> argument.
260) 
261) ??? failure "`%s does not take a SERVICE argument.`"
262) 
263)     The indicated option must not be specified together with the <var>SERVICE</var> argument.
264) 
265) ??? failure "`Cannot load vault settings: %s.`"
266) 
267)     There was a fatal problem loading the stored vault configuration data.
268)     Further details are contained in the variable part of the message.
269) 
270) ??? failure "`Cannot store vault settings: %s.`"
271) 
272)     There was a fatal problem saving the vault configuration data.
273)     Further details are contained in the variable part of the message.
274) 
275) ??? failure "`Cannot import vault settings: %s.`"
276) 
277)     There was a fatal problem loading the imported vault configuration data.
278)     Further details are contained in the variable part of the message.
279) 
280) ??? failure "`Cannot export vault settings: %s.`"
281) 
282)     There was a fatal problem saving the exported vault configuration data.
283)     Further details are contained in the variable part of the message.
284) 
285) ??? failure "`Cannot load user config: %s.`"
286) 
287)     There was a fatal problem loading the central user configuration file.
288)     Further details are contained in the variable part of the message.
289) 
290) ??? failure "`The user configuration file is invalid.`"
291) 
292)     (Exactly what it says.)
293) 
294) ??? failure "`No usable SSH keys were found`"
295) 
296)     The running SSH agent does not contain any suitable SSH keys.
297) 
298) ??? failure "`No valid SSH key selected`"
299) 
300)     We requested that an SSH key be selected, but we got an invalid selection.
301) 
302) ??? failure "`The requested SSH key is not loaded into the agent.`"
303) 
304)     The running SSH agent does not contain the necessary SSH key.
305) 
306) ??? failure "`Cannot find any running SSH agent because SSH_AUTH_SOCK is not set.`"
307) 
308)     We require a running SSH agent, but cannot locate its communication channel, which is normally indicated by the `SSH_AUTH_SOCK` environment variable.
309) 
310) ??? failure "`Cannot connect to an SSH agent because this Python version does not support UNIX domain sockets.`"
311) 
312)     This Python installation does not support the communication mechanism necessary to talk to SSH agents.
313) 
314) ??? failure "`Cannot connect to the SSH agent: %s.`"
315) 
316)     We cannot connect to the SSH agent indicated by the `SSH_AUTH_SOCK` environment variable.
317)     Further details are contained in the variable part of the message.
318) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

319) ??? failure "`The SSH agent failed to or refused to supply a list of loaded keys.`"
320) 
321)     The SSH agent---while responsive in principle---did not fulfill the request.
322) 
323) ??? failure "`The SSH agent failed to or refused to issue a signature with the selected key, necessary for deriving a service passphrase.`"
324) 
325)     The SSH agent---while responsive in principle---failed to cooperate with deriving a service passphrase from the selected master SSH key.
Marco Ricci Extract translatable log me...

Marco Ricci authored 2 weeks ago

326) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

327) ??? failure "`The SSH agent contains no keys suitable for derivepassphrase.`"
328) 
329)     None of the keys loaded into the SSH agent (if any) are suitable for use with <b>derivepassphrase vault</b>.  See the ["SSH KEY SUITABILITY"](#ssh-key-suitability) section for the requirements the SSH key and the SSH agent must fulfill to be suitable.
Marco Ricci Extract translatable log me...

Marco Ricci authored 2 weeks ago

330) 
331) ??? failure "`Error communicating with the SSH agent`"
332) 
333)     There was a system error communicating with the SSH agent.
334) 
Marco Ricci Add more translatable strin...

Marco Ricci authored 1 week ago

335) ??? failure "`Cannot understand the SSH agent's response because it violates the communication protocol.`"
336) 
337)     (Exactly what it says.)
338) 
Marco Ricci Extract translatable log me...

Marco Ricci authored 2 weeks ago

339) ??? failure "`Not saving any new notes: the user aborted the request.`"
340) 
341)     (Exactly what it says.)
342) 
343) ??? failure "`Cannot update %s settings without actual settings.`"
344) 
345)     Using `--config` requires at least one of the `--phrase`, `--key`, `--length`, etc. options.
346) 
347) ??? failure "`Attempted to unset and set %s at the same time.`"
348) 
349)     While handling `--config`, the same configuration setting was passed as an option and as an argument to `--unset`.
350) 
351) ??? failure "`Generating a passphrase requires a SERVICE.`"
352) 
353)     (Exactly what it says.)
354) 
355) ??? failure "`No passphrase or key was given in the configuration.`"
356) 
357)     <b>derivepassphrase vault</b> does not know whether to use a master SSH key or a master passphrase.
358) 
359) ??? failure "`No passphrase was given: the user aborted the request.`"
360) 
361)     (Exactly what it says.)
362) 
363) ??? failure "`No SSH key was selected: the user aborted the request.`"
364) 
365)     (Exactly what it says.)
366) 
367) ### Non-fatal warning and info messages on standard error
368) 
369) (`%s` indicates a variable part of the message.)
370) 
371) ??? warning "`The %s passphrase is not %s-normalized.`"
372) 
373)     The indicated passphrase---as a Unicode string---is not properly normalized according to the preferred Unicode normalization form (as specified in the central configuration file).
374)     It is therefore possible that the passphrase---as a byte string---is not the same byte string as you expect it to be (even though it *looks* correct), and that the derived passphrases thus do not match their expected values either.
375)     Please double-check.
376) 
377) ??? warning "`An empty SERVICE is not supported by vault(1).`"
378) 
379)     <i>vault</i>(1) does not support the empty string as a value for <var>SERVICE</var>; it will treat the <var>SERVICE</var> as missing.
380)     For compatibility, <b>derivepassphrase vault</b> will do the same.
381)     In particular, if the empty service is imported in a configuration via `--import`, then this service cannot be accessed via the <b>derivepassphrase vault</b> command-line.
382) 
383) ??? warning "`Replacing invalid value %s for key %s with %s.`"
384) 
385)     When importing a configuration, the indicated invalid value has been replaced with the indicated replacement value.
386)     (The "interpretation" of the configuration doesn’t change).
387) 
388) ??? warning "`Removing ineffective setting %s = %s.`"
389) 
390)     When importing a configuration, the indicated ineffective setting has been removed.
391)     (The "interpretation" of the configuration doesn’t change).
392) 
393) ??? warning "`Setting a %s passphrase is ineffective because a key is also set.`"
394) 
395)     The configuration (global or key-specific) contains both a stored master passphrase and an SSH key.
396)     The master passphrase will not take effect.
397) 
398) ??? warning "`A subcommand will be required in v1.0.`"
399) 
400)     [Since v0.2.0, until v1.0.]
401)     This command now requires a subcommand.
402)     For compatibility, it currently defaults to "vault".
403) 
404) ??? warning "`Using deprecated v0.1-style config file %s, instead of v0.2-style %s.`"
405) 
406)     [Since v0.2.0, until v1.0.]
407)     A configuration file has been renamed.
408)     <b>derivepassphrase vault</b> will attempt to rename the file itself (`Successfully migrated to %s.`), or complain if it cannot rename it (`Failed to migrate to %s: %s`).
409) 
Marco Ricci Add an actual derivepassphr...

Marco Ricci authored 2 weeks ago

410) ## COMPATIBILITY
411) 
412) ### With other software
413) 
414) <b>derivepassphrase vault</b> is <em>almost</em> drop-in compatible with James Coglan’s <i>vault</i>(1), version 0.3.0 (including "storeroom" support), meaning that each tool supports the same file formats and command-line arguments/options as the other one.
415) 
416) Exceptions:
417) 
418)   * <i>vault</i>(1) does not support the ["Compatibility and extension options"](#compatibility-and-extension-options) listed above.
419) 
420)   * <b>derivepassphrase vault</b> can import and generate configuration exports in the same format as <i>vault</i>(1), but it cannot <em>natively</em> read or write <i>vault</i>(1)'s configuration file (non-storeroom) or configuration directory (storeroom).
421)     (The sister command <i>derivepassphrase-export</i>(1) can read both these formats and export the contents.)
422) 
423) ### Forward and backward compatibility
424) 
425)   * [Since v0.2.0.]
426)     In v1.0, the commands <b>derivepassphrase</b> and <b>derivepassphrase export</b> will require an explicit subcommand name.
427)     Both default to the subcommand <b>vault</b>.
428)   * [Since v0.2.0.]
429)     In v1.0, the configuration data file for the <b>vault</b> subcommand will be named `vault.json`, instead of `config.json`.
430)   * [Since v0.2.0, to be removed in v1.0.]
431)     An existing configuration data file `config.json` will be attempted to be renamed to `vault.json`.
Marco Ricci Reintegrate all functionali...

Marco Ricci authored 3 months ago

432) 
433) ## SEE ALSO
434)