Marco Ricci commited on 2025-06-18 06:50:33
Zeige 4 geänderte Dateien mit 491 Einfügungen und 116 Löschungen.
... | ... |
@@ -1225,6 +1225,57 @@ |
1225 | 1225 |
</label> |
1226 | 1226 |
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix> |
1227 | 1227 |
|
1228 |
+ <li class="md-nav__item"> |
|
1229 |
+ <a href="#v0.5" class="md-nav__link"> |
|
1230 |
+ <span class="md-ellipsis"> |
|
1231 |
+ 0.5 (2025-06-14) |
|
1232 |
+ </span> |
|
1233 |
+ </a> |
|
1234 |
+ |
|
1235 |
+ <nav class="md-nav" aria-label="0.5 (2025-06-14)"> |
|
1236 |
+ <ul class="md-nav__list"> |
|
1237 |
+ |
|
1238 |
+ <li class="md-nav__item"> |
|
1239 |
+ <a href="#removed-in-v0.5" class="md-nav__link"> |
|
1240 |
+ <span class="md-ellipsis"> |
|
1241 |
+ Removed |
|
1242 |
+ </span> |
|
1243 |
+ </a> |
|
1244 |
+ |
|
1245 |
+</li> |
|
1246 |
+ |
|
1247 |
+ <li class="md-nav__item"> |
|
1248 |
+ <a href="#added-in-v0.5" class="md-nav__link"> |
|
1249 |
+ <span class="md-ellipsis"> |
|
1250 |
+ Added |
|
1251 |
+ </span> |
|
1252 |
+ </a> |
|
1253 |
+ |
|
1254 |
+</li> |
|
1255 |
+ |
|
1256 |
+ <li class="md-nav__item"> |
|
1257 |
+ <a href="#changed-in-v0.5" class="md-nav__link"> |
|
1258 |
+ <span class="md-ellipsis"> |
|
1259 |
+ Changed |
|
1260 |
+ </span> |
|
1261 |
+ </a> |
|
1262 |
+ |
|
1263 |
+</li> |
|
1264 |
+ |
|
1265 |
+ <li class="md-nav__item"> |
|
1266 |
+ <a href="#fixed-in-v0.5" class="md-nav__link"> |
|
1267 |
+ <span class="md-ellipsis"> |
|
1268 |
+ Fixed |
|
1269 |
+ </span> |
|
1270 |
+ </a> |
|
1271 |
+ |
|
1272 |
+</li> |
|
1273 |
+ |
|
1274 |
+ </ul> |
|
1275 |
+ </nav> |
|
1276 |
+ |
|
1277 |
+</li> |
|
1278 |
+ |
|
1228 | 1279 |
<li class="md-nav__item"> |
1229 | 1280 |
<a href="#v0.4.0" class="md-nav__link"> |
1230 | 1281 |
<span class="md-ellipsis"> |
... | ... |
@@ -1676,6 +1727,57 @@ |
1676 | 1727 |
</label> |
1677 | 1728 |
<ul class="md-nav__list" data-md-component="toc" data-md-scrollfix> |
1678 | 1729 |
|
1730 |
+ <li class="md-nav__item"> |
|
1731 |
+ <a href="#v0.5" class="md-nav__link"> |
|
1732 |
+ <span class="md-ellipsis"> |
|
1733 |
+ 0.5 (2025-06-14) |
|
1734 |
+ </span> |
|
1735 |
+ </a> |
|
1736 |
+ |
|
1737 |
+ <nav class="md-nav" aria-label="0.5 (2025-06-14)"> |
|
1738 |
+ <ul class="md-nav__list"> |
|
1739 |
+ |
|
1740 |
+ <li class="md-nav__item"> |
|
1741 |
+ <a href="#removed-in-v0.5" class="md-nav__link"> |
|
1742 |
+ <span class="md-ellipsis"> |
|
1743 |
+ Removed |
|
1744 |
+ </span> |
|
1745 |
+ </a> |
|
1746 |
+ |
|
1747 |
+</li> |
|
1748 |
+ |
|
1749 |
+ <li class="md-nav__item"> |
|
1750 |
+ <a href="#added-in-v0.5" class="md-nav__link"> |
|
1751 |
+ <span class="md-ellipsis"> |
|
1752 |
+ Added |
|
1753 |
+ </span> |
|
1754 |
+ </a> |
|
1755 |
+ |
|
1756 |
+</li> |
|
1757 |
+ |
|
1758 |
+ <li class="md-nav__item"> |
|
1759 |
+ <a href="#changed-in-v0.5" class="md-nav__link"> |
|
1760 |
+ <span class="md-ellipsis"> |
|
1761 |
+ Changed |
|
1762 |
+ </span> |
|
1763 |
+ </a> |
|
1764 |
+ |
|
1765 |
+</li> |
|
1766 |
+ |
|
1767 |
+ <li class="md-nav__item"> |
|
1768 |
+ <a href="#fixed-in-v0.5" class="md-nav__link"> |
|
1769 |
+ <span class="md-ellipsis"> |
|
1770 |
+ Fixed |
|
1771 |
+ </span> |
|
1772 |
+ </a> |
|
1773 |
+ |
|
1774 |
+</li> |
|
1775 |
+ |
|
1776 |
+ </ul> |
|
1777 |
+ </nav> |
|
1778 |
+ |
|
1779 |
+</li> |
|
1780 |
+ |
|
1679 | 1781 |
<li class="md-nav__item"> |
1680 | 1782 |
<a href="#v0.4.0" class="md-nav__link"> |
1681 | 1783 |
<span class="md-ellipsis"> |
... | ... |
@@ -2039,55 +2141,305 @@ Semantic Versioning and Keep a Changelog definitions.</p> |
2039 | 2141 |
</li> |
2040 | 2142 |
</ul> |
2041 | 2143 |
</details> |
2144 |
+<div class="admonition abstract inline end"> |
|
2145 |
+<p class="admonition-title">Legend: symbols</p> |
|
2146 |
+<p><ul style="list-style-type: none;"> |
|
2147 |
+<li><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span> — a related bug entry from the wishlist page |
|
2148 |
+<li><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span> — a related wishlist entry from the wishlist page |
|
2149 |
+</ul></p> |
|
2150 |
+</div> |
|
2042 | 2151 |
<aside> |
2043 | 2152 |
<p><small> |
2044 |
-(All entries are from the perspective of a user, not a developer.) |
|
2153 |
+(All entries are from the perspective of a user of the program or the API. |
|
2154 |
+As an exception, entries partaining to developers of <code>derivepassphrase</code> are |
|
2155 |
+specifically marked as such.) |
|
2045 | 2156 |
</small></p> |
2046 | 2157 |
</aside> |
2047 | 2158 |
<!-- scriv changelog start --> |
2048 | 2159 |
|
2160 |
+<h2 id="v0.5">0.5 (2025-06-14)<a class="headerlink" href="#v0.5" title="Permanent link">¶</a></h2> |
|
2161 |
+<h3 id="removed-in-v0.5">Removed<a class="headerlink" href="#removed-in-v0.5" title="Permanent link">¶</a></h3> |
|
2162 |
+<ul> |
|
2163 |
+<li> |
|
2164 |
+<p>For <a href="../reference/derivepassphrase.1/"><code>derivepassphrase</code></a>, remove <a href="#added-in-v0.4.0-color-support">support for (automatic) colored |
|
2165 |
+ output or output with embedded text styling, as introduced in |
|
2166 |
+ v0.4.0</a>.</p> |
|
2167 |
+<p>This is a stopgap measure. |
|
2168 |
+There exist pseudo-standards (the <code>NO_COLOR</code> and <code>FORCE_COLOR</code> |
|
2169 |
+environment variables) governing how to influence this automatic |
|
2170 |
+detection, but they are under-specified with regard to their interaction |
|
2171 |
+with each other. |
|
2172 |
+Until a consensus is reached and automatic colored/styled output can be |
|
2173 |
+requested or rejected reliably across different terminal programs, we |
|
2174 |
+will rather emit only uncolored, unstyled, lowest-common-denominator |
|
2175 |
+device-independent output. |
|
2176 |
+→<a href="../wishlist/conventional-configurable-text-styling/" title="Wish entry: “derivepassphrase vault should support conventional and configurable text styling”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2177 |
+</li> |
|
2178 |
+</ul> |
|
2179 |
+<h3 id="added-in-v0.5">Added<a class="headerlink" href="#added-in-v0.5" title="Permanent link">¶</a></h3> |
|
2180 |
+<ul> |
|
2181 |
+<li> |
|
2182 |
+<p>For the <a class="autorefs autorefs-internal" title=" Vault" href="../reference/derivepassphrase.vault/#derivepassphrase.vault.Vault"><code>Vault</code></a> API, support reporting |
|
2183 |
+ on whether two master passphrases are interchangable with respect to the |
|
2184 |
+ service passphrases they can derive. |
|
2185 |
+ This is an artefact of how the master passphrase is converted to the |
|
2186 |
+ random bit sequence with which the service passphrases are generated. |
|
2187 |
+ See the corresponding <a href="../explanation/faq-vault-interchangable-passphrases/">FAQ entry: What are “interchangable passphrases” |
|
2188 |
+ in vault?</a> for details, including the |
|
2189 |
+ practical security (non-)implications.</p> |
|
2190 |
+<p>The <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a> command-line interface does |
|
2191 |
+not address this in any manner, mostly because the “non-standard” |
|
2192 |
+interchangable variants of a given master password tend to be ugly to |
|
2193 |
+type in, and because they do not have practical security implications.</p> |
|
2194 |
+</li> |
|
2195 |
+<li> |
|
2196 |
+<p>For the <a class="autorefs autorefs-internal" title=" Vault" href="../reference/derivepassphrase.vault/#derivepassphrase.vault.Vault"><code>Vault</code></a> API, accept arbitrary |
|
2197 |
+ <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/collections.abc.html#collections.abc.Buffer">Buffer</a> objects as passphrases or service |
|
2198 |
+ names, beyond <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/stdtypes.html#bytes"><code>bytes</code></a> and <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/stdtypes.html#bytearray"><code>bytearray</code></a>.</p> |
|
2199 |
+</li> |
|
2200 |
+<li> |
|
2201 |
+<p>Expose <a class="autorefs autorefs-internal" title=" UUID |
|
2202 |
+ |
|
2203 |
+ |
|
2204 |
+ |
|
2205 |
+ class-attribute |
|
2206 |
+ instance-attribute |
|
2207 |
+ " href="../reference/derivepassphrase.vault/#derivepassphrase.vault.Vault.UUID">the vault UUID</a> and <a class="autorefs autorefs-internal" title=" CHARSETS |
|
2208 |
+ |
|
2209 |
+ |
|
2210 |
+ |
|
2211 |
+ class-attribute |
|
2212 |
+ instance-attribute |
|
2213 |
+ " href="../reference/derivepassphrase.vault/#derivepassphrase.vault.Vault.CHARSETS">the |
|
2214 |
+ character sets</a> as public |
|
2215 |
+ attributes.</p> |
|
2216 |
+</li> |
|
2217 |
+<li> |
|
2218 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, support selecting the <a href="#changed-in-v0.5-editor-interface">editor |
|
2219 |
+ interface</a> when editing notes via the |
|
2220 |
+ <code>--modern-editor-interface</code> and <code>--vault-legacy-editor-interface</code> |
|
2221 |
+ options.</p> |
|
2222 |
+</li> |
|
2223 |
+<li> |
|
2224 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, support printing the service |
|
2225 |
+ notes before the passphrase, as an alternative, instead of always |
|
2226 |
+ printing them <em>after</em> the passphrase. |
|
2227 |
+ →<a href="../wishlist/print-service-notes-above/" title="Wish entry: “derivepassphrase vault should be able to print service notes above the passphrase”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2228 |
+</li> |
|
2229 |
+<li> |
|
2230 |
+<p>In the <code>--version</code> option of <a href="../reference/derivepassphrase.1/"><code>derivepassphrase</code></a> and each |
|
2231 |
+ subcommand, additionally report build and environment information, such |
|
2232 |
+ as supported subcommands, derivation schemes, foreign configuration |
|
2233 |
+ formats and active <a href="https://peps.python.org/pep-0508/">PEP 508 extras</a>. |
|
2234 |
+ (Each subcommand only reports the items relevant to that subcommand.) |
|
2235 |
+ →<a href="../wishlist/report-build-flags-and-features/" title="Wish entry: “derivepassphrase should report its build flags and supported features”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2236 |
+</li> |
|
2237 |
+<li> |
|
2238 |
+<p>For developers: Rewrite the tests concerning <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase |
|
2239 |
+ vault</code></a> and <code>--notes</code> usage into <a href="https://pypi.org/project/hypothesis/">hypothesis</a>-based tests |
|
2240 |
+ where feasible.</p> |
|
2241 |
+</li> |
|
2242 |
+<li> |
|
2243 |
+<p>For developers: Add scripts to the source tree to ensure consistent code |
|
2244 |
+ quality: automatic linting, formatting and type checking, and optional |
|
2245 |
+ running of the test suite and building of the documentation. |
|
2246 |
+ The master quality control script doubles as a servicable (but |
|
2247 |
+ heavyweight) “pre-commit” hook for git.</p> |
|
2248 |
+</li> |
|
2249 |
+</ul> |
|
2250 |
+<h3 id="changed-in-v0.5">Changed<a class="headerlink" href="#changed-in-v0.5" title="Permanent link">¶</a></h3> |
|
2251 |
+<ul> |
|
2252 |
+<li> |
|
2253 |
+<p>Support a new, unified interface |
|
2254 |
+ <a class="autorefs autorefs-internal" title=" ExportVaultConfigDataFunction" href="../reference/derivepassphrase.exporter/#derivepassphrase.exporter.ExportVaultConfigDataFunction"><code>ExportVaultConfigDataFunction</code></a> |
|
2255 |
+ in the export handlers for “storeroom” and “vault-native” configuration |
|
2256 |
+ data, |
|
2257 |
+ <a class="autorefs autorefs-internal" title=" export_storeroom_data" href="../reference/derivepassphrase.exporter/#derivepassphrase.exporter.storeroom.export_storeroom_data"><code>export_storeroom_data</code></a> |
|
2258 |
+ and |
|
2259 |
+ <a class="autorefs autorefs-internal" title=" export_vault_native_data" href="../reference/derivepassphrase.exporter/#derivepassphrase.exporter.vault_native.export_vault_native_data"><code>export_vault_native_data</code></a>. |
|
2260 |
+ A new dispatch function |
|
2261 |
+ <a class="autorefs autorefs-internal" title=" export_vault_config_data" href="../reference/derivepassphrase.exporter/#derivepassphrase.exporter.export_vault_config_data"><code>export_vault_config_data</code></a> |
|
2262 |
+ automatically calls the correct backend, based on the requested format.</p> |
|
2263 |
+<p>This is a <strong>breaking API change</strong> due to the change in function |
|
2264 |
+parameter names and return types.</p> |
|
2265 |
+</li> |
|
2266 |
+<li> |
|
2267 |
+<p>Convert <code>KeyCommentPair</code> from <a class="autorefs autorefs-internal" title=" derivepassphrase._types" href="../reference/derivepassphrase._types/#derivepassphrase._types"><code>derivepassphrase._types</code></a>, and |
|
2268 |
+ <code>KeyPair</code> and <code>MasterKeys</code> from |
|
2269 |
+ <a class="autorefs autorefs-internal" title=" derivepassphrase.exporter.storeroom" href="../reference/derivepassphrase.exporter/#derivepassphrase.exporter.storeroom"><code>derivepassphrase.exporter.storeroom</code></a>, to |
|
2270 |
+ <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/typing.html#typing.NamedTuple"><code>NamedTuple</code>s</a>. Also rename them to |
|
2271 |
+ <a class="autorefs autorefs-internal" title=" SSHKeyCommentPair" href="../reference/derivepassphrase._types/#derivepassphrase._types.SSHKeyCommentPair"><code>SSHKeyCommentPair</code></a>, |
|
2272 |
+ <a class="autorefs autorefs-internal" title=" StoreroomKeyPair" href="../reference/derivepassphrase._types/#derivepassphrase._types.StoreroomKeyPair"><code>StoreroomKeyPair</code></a> and |
|
2273 |
+ <a class="autorefs autorefs-internal" title=" StoreroomMasterKeys" href="../reference/derivepassphrase._types/#derivepassphrase._types.StoreroomMasterKeys"><code>StoreroomMasterKeys</code></a>, |
|
2274 |
+ respectively, in the <a class="autorefs autorefs-internal" title=" derivepassphrase._types" href="../reference/derivepassphrase._types/#derivepassphrase._types"><code>derivepassphrase._types</code></a> module.</p> |
|
2275 |
+<p>This is a <strong>breaking API change</strong>.</p> |
|
2276 |
+</li> |
|
2277 |
+<li> |
|
2278 |
+<p>Move the non-essential content of the <a class="autorefs autorefs-internal" title=" derivepassphrase.cli" href="../reference/derivepassphrase.cli/#derivepassphrase.cli"><code>derivepassphrase.cli</code></a> module |
|
2279 |
+ into the “internals” subpackage.</p> |
|
2280 |
+<p>This is a <strong>breaking API change</strong> due to the removal of most functions |
|
2281 |
+from the <a class="autorefs autorefs-internal" title=" derivepassphrase.cli" href="../reference/derivepassphrase.cli/#derivepassphrase.cli"><code>derivepassphrase.cli</code></a> module.</p> |
|
2282 |
+</li> |
|
2283 |
+<li> |
|
2284 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, change the handling of the |
|
2285 |
+ notes for better compatibility with <i>vault</i>(1) and for better |
|
2286 |
+ internal consistency:</p> |
|
2287 |
+<ol> |
|
2288 |
+<li> |
|
2289 |
+<p>Correctly require the <code>--config</code> option in addition to the <code>--notes</code> |
|
2290 |
+ option to request that the service notes be edited, for |
|
2291 |
+ compatibility with <i>vault</i>(1). |
|
2292 |
+ Issue a warning if <code>--notes</code> is used without <code>--config</code>.</p> |
|
2293 |
+</li> |
|
2294 |
+<li> |
|
2295 |
+<p><code>notes</code> is now also a valid setting name for <code>--unset</code> to take.</p> |
|
2296 |
+</li> |
|
2297 |
+<li> |
|
2298 |
+<p>Editing the notes successfully in any way, including no-op edits, |
|
2299 |
+ will register the service name as a known service to |
|
2300 |
+ <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, even if the settings are |
|
2301 |
+ otherwise empty.</p> |
|
2302 |
+</li> |
|
2303 |
+</ol> |
|
2304 |
+</li> |
|
2305 |
+<li> |
|
2306 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, by default, use an <b |
|
2307 |
+ id="changed-in-v0.5-editor-interface">editor interface</b> that matches |
|
2308 |
+ <i>vault</i>(1): the contents of the edited text file are used directly |
|
2309 |
+ as the service notes, without interpretation.</p> |
|
2310 |
+<p>Previously, we post-processed the text file to remove comments and our |
|
2311 |
+instruction texts, and interpreted an empty file as a request to abort |
|
2312 |
+the edit. |
|
2313 |
+These two editor interfaces (“legacy” and “modern”) can be explicitly |
|
2314 |
+selected, and for the legacy interface, which is less resilient against |
|
2315 |
+data entry or usage errors, a backup copy of the old notes content is |
|
2316 |
+made.</p> |
|
2317 |
+</li> |
|
2318 |
+<li> |
|
2319 |
+<p>For developers: Use a different feature matrix and different |
|
2320 |
+ <a href="https://pypi.org/project/hypothesis/">hypothesis</a> profiles in the test suite. |
|
2321 |
+ The slowdown caused by coverage measurement is now more accurately |
|
2322 |
+ estimated and adjusted for in the <a href="https://pypi.org/project/hypothesis/">hypothesis</a> settings.</p> |
|
2323 |
+</li> |
|
2324 |
+<li> |
|
2325 |
+<p>For developers: Clean up, partly reorganize, and document the test |
|
2326 |
+ suite, at least rudimentarily. |
|
2327 |
+ Also add several new <a href="https://pypi.org/project/hypothesis/">hypothesis</a>-based tests, particularly to test |
|
2328 |
+ the core assumptions of the <a class="autorefs autorefs-internal" title=" derivepassphrase.vault" href="../reference/derivepassphrase.vault/#derivepassphrase.vault">vault</a> derivation |
|
2329 |
+ scheme about sensitivity (or lack thereof) to its inputs and its input |
|
2330 |
+ formats.</p> |
|
2331 |
+</li> |
|
2332 |
+<li> |
|
2333 |
+<p>For developers: For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, store our |
|
2334 |
+ <code>vault.json</code> data file in pretty-printed form. |
|
2335 |
+ This is a stopgap measure to ease debugging and introspection until |
|
2336 |
+ better built-in query functionality for the effective configuration is |
|
2337 |
+ available, because users should not be rewarded for meddling around in |
|
2338 |
+ data files. |
|
2339 |
+ →<a href="../wishlist/pretty-print-json/" title="Wish entry: “derivepassphrase vault should store and export the vault configuration in pretty-printed JSON”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2340 |
+</li> |
|
2341 |
+</ul> |
|
2342 |
+<h3 id="fixed-in-v0.5">Fixed<a class="headerlink" href="#fixed-in-v0.5" title="Permanent link">¶</a></h3> |
|
2343 |
+<ul> |
|
2344 |
+<li> |
|
2345 |
+<p>Fix the misbehaving shell completion for <code>zsh</code> in the presence of colons |
|
2346 |
+ in the completion item. |
|
2347 |
+ This was due to an overzealous workaround for |
|
2348 |
+ <a href="https://github.com/pallets/click/issues/2703"><code>pallets/click#2703</code></a>.</p> |
|
2349 |
+</li> |
|
2350 |
+<li> |
|
2351 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, when exporting a vault |
|
2352 |
+ configuration, export a pretty-printed configuration, to ease debugging |
|
2353 |
+ and introspection. |
|
2354 |
+ →<a href="../wishlist/pretty-print-json/" title="Wish entry: “derivepassphrase vault should store and export the vault configuration in pretty-printed JSON”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2355 |
+</li> |
|
2356 |
+<li> |
|
2357 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, also print the service notes |
|
2358 |
+ (if any) when deriving a service passphrase, just like <i>vault</i>(1) |
|
2359 |
+ does. |
|
2360 |
+ →<a href="../wishlist/print-service-notes/" title="Bug entry: “derivepassphrase vault does not print service notes”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2361 |
+</li> |
|
2362 |
+<li> |
|
2363 |
+<p>Lock our internals and their configuration against concurrent |
|
2364 |
+ modifications. |
|
2365 |
+ →<a href="../wishlist/concurrency-audit/" title="Bug entry: “Audit derivepassphrase for concurrency/thread-safety issues”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2366 |
+</li> |
|
2367 |
+<li> |
|
2368 |
+<p>Test against PyPy 3.11.</p> |
|
2369 |
+</li> |
|
2370 |
+<li> |
|
2371 |
+<p>Test on <abbr title="Microsoft Windows">The Annoying |
|
2372 |
+ OS</abbr><sup id="fnref:the-annoying-os"><a class="footnote-ref" href="#fn:the-annoying-os">1</a></sup> in its baseline version, i.e., without SSH |
|
2373 |
+ agent functionality but with <code>cryptography</code> support. |
|
2374 |
+ Fix all incompatibilities in the test suite if essential and/or |
|
2375 |
+ feasible, otherwise document them as skips or expected failures.</p> |
|
2376 |
+<p>(The latter case currently only concerns one single test that is |
|
2377 |
+supposed to trigger OS errors while attempting to read the |
|
2378 |
+<code>derivepassphrase</code> configuration files. |
|
2379 |
+<abbr title="Microsoft Windows">The Annoying OS</abbr> happily returns |
|
2380 |
+an empty file instead.)</p> |
|
2381 |
+</li> |
|
2382 |
+<li> |
|
2383 |
+<p>For developers: Include build machinery to ensure consistency of our |
|
2384 |
+ version number and our diagnostic messages between the documentation and |
|
2385 |
+ the code, instead of having to check this by hand.</p> |
|
2386 |
+<p>(The canonical way to get the version number is the |
|
2387 |
+<a class="autorefs autorefs-external" href="https://docs.python.org/3/library/importlib.metadata.html#importlib.metadata.version"><code>importlib.metadata.version</code></a> standard library interface.)</p> |
|
2388 |
+</li> |
|
2389 |
+<li> |
|
2390 |
+<p>For developers: Test our locking implementation for correctness, on both |
|
2391 |
+ sides of the API. |
|
2392 |
+ Specifically, test that the respective platform-specific locking |
|
2393 |
+ primitives provide the requested mutual exclusion properties, and that |
|
2394 |
+ the locking system as a whole, when given functioning locking |
|
2395 |
+ primitives, correctly serializes access to the facilities it is supposed |
|
2396 |
+ to guard. |
|
2397 |
+ →<a href="../wishlist/concurrency-testing-in-test-suite/" title="Bug entry: “Test for concurrency and assert thread-safety in derivepassphrase's test suite”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2398 |
+</li> |
|
2399 |
+</ul> |
|
2049 | 2400 |
<h2 id="v0.4.0">0.4.0 (2025-01-07)<a class="headerlink" href="#v0.4.0" title="Permanent link">¶</a></h2> |
2050 | 2401 |
<h3 id="added-in-v0.4.0">Added<a class="headerlink" href="#added-in-v0.4.0" title="Permanent link">¶</a></h3> |
2051 | 2402 |
<ul> |
2052 | 2403 |
<li> |
2053 |
-<p>Both <code>derivepassphrase vault</code> and <code>derivepassphrase export vault</code> now |
|
2054 |
- support changing the amount of diagnostic output they emit via new |
|
2055 |
- command-line options <code>--debug</code>, <code>-v</code>/<code>--verbose</code> and <code>-q</code>/<code>--quiet</code>. |
|
2056 |
- Internally, this uses Python’s standard <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/logging.html#module-logging">logging</a> and <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/warnings.html#module-warnings">warnings</a> |
|
2404 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a> and <a href="../reference/derivepassphrase-export-vault.1/"><code>derivepassphrase export |
|
2405 |
+ vault</code></a>, support changing the amount of diagnostic |
|
2406 |
+ output we emit via new command-line options <code>--debug</code>, <code>-v</code>/<code>--verbose</code> |
|
2407 |
+ and <code>-q</code>/<code>--quiet</code>. |
|
2408 |
+ Internally, we use Python’s standard <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/logging.html#module-logging">logging</a> and <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/warnings.html#module-warnings">warnings</a> |
|
2057 | 2409 |
systems.</p> |
2058 | 2410 |
</li> |
2059 | 2411 |
<li> |
2060 |
-<p><code>derivepassphrase</code> now uses a central configuration file, and additional |
|
2061 |
- data files, some of which are service-specific. |
|
2062 |
- (The <code>vault.json</code> |
|
2063 |
- configuration file is now rebranded as a data file.) |
|
2412 |
+<p>Use a central configuration file, and additional data files, some of |
|
2413 |
+ which are service-specific. |
|
2414 |
+ (The <code>vault.json</code> configuration file is now rebranded as a data file.) |
|
2064 | 2415 |
The configuration files are user-editable, the data files are |
2065 |
- <code>derivepassphrase</code>-editable.</p> |
|
2416 |
+ <a href="../reference/derivepassphrase.1/"><code>derivepassphrase</code></a>-editable.</p> |
|
2066 | 2417 |
<p>The configuration files are in TOML format, so installing |
2067 | 2418 |
<code>derivepassphrase</code> on Python 3.10 and older requires the |
2068 | 2419 |
<a href="https://pypi.org/project/tomli/"><code>tomli</code></a> package.</p> |
2069 | 2420 |
</li> |
2070 | 2421 |
<li> |
2071 |
-<p><code>derivepassphrase vault --config</code> now supports an <code>--unset</code> option which |
|
2072 |
- unsets any given named setting prior to applying any other configuration |
|
2073 |
- changes.</p> |
|
2422 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault --config</code></a>, support an <code>--unset</code> |
|
2423 |
+ option which unsets any given named setting prior to applying any other |
|
2424 |
+ configuration changes.</p> |
|
2074 | 2425 |
</li> |
2075 | 2426 |
<li> |
2076 |
-<p><code>derivepassphrase vault --export</code> can now also export the current |
|
2077 |
- configuration as a POSIX <code>sh</code> script, using the <code>--export-as=sh</code> option. |
|
2078 |
- The default (and previous behavior) is <code>--export-as=json</code>.</p> |
|
2427 |
+<p>For <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault --export</code></a>, support exporting |
|
2428 |
+ the current configuration as a POSIX <code>sh</code> script, using the |
|
2429 |
+ <code>--export-as=sh</code> option. The default (and previous behavior) is |
|
2430 |
+ <code>--export-as=json</code>.</p> |
|
2079 | 2431 |
</li> |
2080 | 2432 |
<li> |
2081 |
-<p><code>derivepassphrase</code> now includes basic support for localization: if the |
|
2082 |
- necessary translations are installed, then the diagnostics and help |
|
2083 |
- texts can be emitted in different languages. |
|
2084 |
- Internally, this uses Python’s standard <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/gettext.html#module-gettext"><code>gettext</code></a> system.</p> |
|
2433 |
+<p>Include basic support for localization: if the necessary translations |
|
2434 |
+ are installed, then the diagnostics and help texts can be emitted in |
|
2435 |
+ different languages. |
|
2436 |
+ Internally, we use Python’s standard <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/gettext.html#module-gettext"><code>gettext</code></a> system.</p> |
|
2085 | 2437 |
<p>(As of this version, no translations have actually been prepared yet.)</p> |
2086 | 2438 |
</li> |
2087 | 2439 |
<li> |
2088 |
-<p><code>derivepassphrase</code> now explicitly supports shell completion, in |
|
2089 |
- particular filename and service name completion in the <code>export vault</code> |
|
2090 |
- and <code>vault</code> subcommands.</p> |
|
2440 |
+<p>For <a href="../reference/derivepassphrase.1/"><code>derivepassphrase</code></a>, explicitly support shell completion, in |
|
2441 |
+ particular filename and service name completion in the <a href="../reference/derivepassphrase-export-vault.1/"><code>export |
|
2442 |
+ vault</code></a> and <a href="../reference/derivepassphrase-vault.1/"><code>vault</code></a> subcommands.</p> |
|
2091 | 2443 |
<p>However, because of restrictions regarding the exchange of data between |
2092 | 2444 |
<code>derivepassphrase</code> and the shell, <code>derivepassphrase</code> will not offer any |
2093 | 2445 |
service names containing ASCII control characters for completion, and |
... | ... |
@@ -2095,9 +2447,10 @@ a warning will be issued when importing or configuring such a service. |
2095 | 2447 |
They may still otherwise be used normally.</p> |
2096 | 2448 |
</li> |
2097 | 2449 |
<li> |
2098 |
-<p>Support the semi-standard <code>NO_COLOR</code> and the <code>FORCE_COLOR</code> environment |
|
2099 |
- variables to suppress or force color output from <code>derivepassphrase</code>. |
|
2100 |
- (<code>FORCE_COLOR</code> overrides <code>NO_COLOR</code> if both are set.)</p> |
|
2450 |
+<p><b id="added-in-v0.4.0-color-support">Support the semi-standard |
|
2451 |
+ <code>NO_COLOR</code> and the <code>FORCE_COLOR</code> environment variables</b> to suppress |
|
2452 |
+ or force color output from <a href="../reference/derivepassphrase.1/"><code>derivepassphrase</code></a>. (<code>FORCE_COLOR</code> |
|
2453 |
+ overrides <code>NO_COLOR</code> if both are set.)</p> |
|
2101 | 2454 |
</li> |
2102 | 2455 |
</ul> |
2103 | 2456 |
<h3 id="changed-in-v0.4.0">Changed<a class="headerlink" href="#changed-in-v0.4.0" title="Permanent link">¶</a></h3> |
... | ... |
@@ -2164,16 +2517,17 @@ They may still otherwise be used normally.</p> |
2164 | 2517 |
<h2 id="v0.3.0">0.3.0 (2024-10-15)<a class="headerlink" href="#v0.3.0" title="Permanent link">¶</a></h2> |
2165 | 2518 |
<h3 id="added-in-v0.3.0">Added<a class="headerlink" href="#added-in-v0.3.0" title="Permanent link">¶</a></h3> |
2166 | 2519 |
<ul> |
2167 |
-<li>Convert changelog management from towncrier to <a href="https://pypi.org/project/scriv">scriv</a>.</li> |
|
2520 |
+<li>Convert changelog management from towncrier to <a href="https://pypi.org/project/scriv/">scriv</a>.</li> |
|
2168 | 2521 |
<li>Add SSH agent spawning support to the test suite. |
2169 | 2522 |
Use this support to test the agent functionality on all known major SSH |
2170 | 2523 |
agent implementations automatically. |
2171 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/issues/12">#12</a>)</li> |
|
2524 |
+ →<a href="../wishlist/test-suite-isolated-ssh-agent/" title="Wish entry: “Support and isolate OpenSSH's ssh-agent and PuTTY's pageant in the test suite”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></li> |
|
2172 | 2525 |
<li>Add <a href="https://pypi.org/project/hypothesis/">hypothesis</a>-based tests to the test suite.</li> |
2173 | 2526 |
<li>Update README to add explanations for virtual environments and package |
2174 | 2527 |
extras.</li> |
2175 | 2528 |
<li>Update README to demonstrate configuration storing and SSH agent use. |
2176 |
- Include comments on Windows support for SSH agents.</li> |
|
2529 |
+ Include comments on Windows support for SSH agents. |
|
2530 |
+ →<a href="../wishlist/windows-ssh-agent-support/" title="Bug entry: “Support PuTTY/Pageant (and maybe OpenSSH/ssh-agent) on Windows”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2177 | 2531 |
<li>Use cross-references in the documentation of function signatures.</li> |
2178 | 2532 |
<li>Add proper support for Buffer types in the SSH agent client. |
2179 | 2533 |
Any Python object supporting the buffer protocol can be used as input to |
... | ... |
@@ -2196,11 +2550,11 @@ They may still otherwise be used normally.</p> |
2196 | 2550 |
standard library does.</p> |
2197 | 2551 |
</li> |
2198 | 2552 |
<li> |
2199 |
-<p>Rewrite functionality for checking for valid vault(1) configurations: |
|
2200 |
- include an actual validation function which throws errors upon |
|
2201 |
- encountering format violations, and which allows specifying which types |
|
2202 |
- of extensions (unknown settings, <code>derivepassphrase</code>-only settings) to |
|
2203 |
- tolerate during validation.</p> |
|
2553 |
+<p>Rewrite functionality for checking for valid <i>vault</i>(1) |
|
2554 |
+ configurations: include an actual validation function which throws |
|
2555 |
+ errors upon encountering format violations, and which allows specifying |
|
2556 |
+ which types of extensions (unknown settings, <code>derivepassphrase</code>-only |
|
2557 |
+ settings) to tolerate during validation.</p> |
|
2204 | 2558 |
<p>This is a <strong>breaking API change</strong> because the function return annotation |
2205 | 2559 |
changed, from <a class="autorefs autorefs-external" href="https://docs.python.org/3/library/typing.html#typing.TypeGuard"><code>typing.TypeGuard</code></a> to <a class="autorefs autorefs-external" href="https://typing-extensions.readthedocs.io/en/latest/index.html#typing_extensions.TypeIs"><code>typing_extensions.TypeIs</code></a>. |
2206 | 2560 |
These were the originally intended semantics, but when |
... | ... |
@@ -2211,38 +2565,40 @@ support this kind of partial type narrowing.</p> |
2211 | 2565 |
<p>Fail earlier, and more gracefully/specifically, when we cannot talk to |
2212 | 2566 |
the SSH agent because Python does not support UNIX domain sockets on |
2213 | 2567 |
this system. |
2214 |
- In particular, this is the current situation on Windows.</p> |
|
2568 |
+ In particular, this is the current situation on Windows. |
|
2569 |
+ →<a href="../wishlist/fail-gracefully-without-af-unix/" title="Bug entry: “Fail gracefully if support for UNIX domain sockets is unavailable”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a> |
|
2570 |
+ <a href="../wishlist/windows-ssh-agent-support/" title="Bug entry: “Support PuTTY/Pageant (and maybe OpenSSH/ssh-agent) on Windows”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2215 | 2571 |
<p>This adds another failure case to the <code>SSHAgentClient</code> constructor, and |
2216 | 2572 |
therefore constitutes a <strong>breaking API change</strong>.</p> |
2217 | 2573 |
</li> |
2218 | 2574 |
<li> |
2219 |
-<p>In <code>derivepassphrase vault</code>, accept <code>key</code> and <code>phrase</code> entries just like |
|
2220 |
- vault(1) does: <code>key</code> always overrides <code>phrase</code> in the configuration, no |
|
2221 |
- matter the level.</p> |
|
2575 |
+<p>In <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, accept <code>key</code> and <code>phrase</code> |
|
2576 |
+ entries just like <i>vault</i>(1) does: <code>key</code> always overrides <code>phrase</code> |
|
2577 |
+ in the configuration, no matter the level.</p> |
|
2222 | 2578 |
<p>This is a command-line only change.</p> |
2223 | 2579 |
</li> |
2224 | 2580 |
<li> |
2225 |
-<p>In <code>derivepassphrase vault</code>, when importing settings, accept falsy values |
|
2226 |
- everywhere <code>vault</code> does, with a warning. |
|
2581 |
+<p>In <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, when importing settings, |
|
2582 |
+ accept falsy values everywhere <code>vault</code> does, with a warning. |
|
2227 | 2583 |
Depending on the setting, they are equivalent to zero, the empty string, |
2228 | 2584 |
or “not set”. |
2229 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/issues/17">#17</a>)</p> |
|
2585 |
+ →<a href="../wishlist/falsy-vault-config-values/" title="Bug entry: “derivepassphrase vault differs from vault(1) behavior with falsy stored configuration values”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2230 | 2586 |
<p>This is a command-line only change, and only affects importing. |
2231 | 2587 |
The API provides a new function to normalize falsy settings, but still |
2232 | 2588 |
otherwise requires settings to be of the correct type. |
2233 | 2589 |
Storing a malformed configuration with such falsy values will still |
2234 |
-generate errors when <code>derivepassphrase vault</code> loads the settings from |
|
2235 |
-disk.</p> |
|
2590 |
+generate errors when <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a> loads the |
|
2591 |
+settings from disk.</p> |
|
2236 | 2592 |
</li> |
2237 | 2593 |
<li> |
2238 |
-<p>In <code>derivepassphrase vault</code>, when importing configurations, |
|
2239 |
- correctly merge them with the existing one, same as vault(1): keep |
|
2240 |
- all named services and their settings (and the global settings if |
|
2594 |
+<p>In <a href="../reference/derivepassphrase-vault.1/"><code>derivepassphrase vault</code></a>, when importing configurations, |
|
2595 |
+ correctly merge them with the existing one, same as <i>vault</i>(1): |
|
2596 |
+ keep all named services and their settings (and the global settings if |
|
2241 | 2597 |
applicable) that are not mentioned in the imported configuration. |
2242 | 2598 |
The import procedure is thus more akin to a section-wise import of |
2243 | 2599 |
the configurations, instead of a “full” import, and the resulting |
2244 | 2600 |
configuration generally is a merge of both inputs. |
2245 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/issues/16">#16</a>)</p> |
|
2601 |
+ →<a href="../wishlist/amend-vault-config/" title="Bug entry: “derivepassphrase vault --import overwrites config instead of amending it”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></p> |
|
2246 | 2602 |
</li> |
2247 | 2603 |
<li> |
2248 | 2604 |
<p>The following operations or configuration settings now raise |
... | ... |
@@ -2272,12 +2628,12 @@ disk.</p> |
2272 | 2628 |
storeroom formats.</p> |
2273 | 2629 |
<p>This feature requires the <code>cryptography</code> Python module, but is available |
2274 | 2630 |
even if <code>vault</code> is not installed. |
2275 |
-(<a href="https://github.com/the-13th-letter/derivepassphrase/1">#1</a>)</p> |
|
2631 |
+→<a href="../wishlist/export-vault-formats/" title="Wish entry: “Support data export from vault v0.2, vault v0.3, and storeroom storage formats”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2276 | 2632 |
</li> |
2277 | 2633 |
</ul> |
2278 | 2634 |
<h3 id="fixed-in-v0.2.0">Fixed<a class="headerlink" href="#fixed-in-v0.2.0" title="Permanent link">¶</a></h3> |
2279 | 2635 |
<ul> |
2280 |
-<li>Deploy versioned documentation with <a href="https://pypi.org/project/mike">mike</a>. |
|
2636 |
+<li>Deploy versioned documentation with <a href="https://pypi.org/project/mike/">mike</a>. |
|
2281 | 2637 |
Set up a “latest” tag and the “0.<var>x</var>” version of the |
2282 | 2638 |
documentation with the contents so far.</li> |
2283 | 2639 |
</ul> |
... | ... |
@@ -2288,20 +2644,20 @@ even if <code>vault</code> is not installed. |
2288 | 2644 |
Further moved <code>derivepassphrase.Vault</code> and |
2289 | 2645 |
<code>derivepassphrase.AmbiguousByteRepresentation</code> into a new submodule |
2290 | 2646 |
<code>vault</code>, and renamed submodule <code>ssh_agent_client</code> to <code>ssh_agent</code>. |
2291 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/3">#3</a>)</li> |
|
2647 |
+ →<a href="../wishlist/single-toplevel-module/" title="Bug entry: “Move sequin and ssh_agent_client modules into derivepassphrase package”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2292 | 2648 |
<li>Changed internal error handling and error messages, to better work in |
2293 | 2649 |
the context of a command-line tool. |
2294 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/4">#4</a>)</li> |
|
2650 |
+ →<a href="../wishlist/better-error-messages/" title="Bug entry: “Improve common error messages in the command-line interface”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2295 | 2651 |
<li>Combine and consolidate <code>derivepassphrase.types</code> and |
2296 | 2652 |
<code>derivepassphrase.ssh_agent.types</code> into a new submodule |
2297 | 2653 |
<code>derivepassphrase._types</code>. |
2298 | 2654 |
Despite the name, the module is public. |
2299 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/7">#7</a>)</li> |
|
2655 |
+ →<a href="../wishlist/no-stdlib-module-names/" title="Bug entry: “Rename types submodules to _types”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2300 | 2656 |
<li>Warn the user when entering (directly, or via configuration |
2301 | 2657 |
editing/importing) a passphrase that is not in the configured Unicode |
2302 | 2658 |
normalization form. |
2303 | 2659 |
(But don’t otherwise reject any textual master passphrases.) |
2304 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/9">#9</a>)</li> |
|
2660 |
+ →<a href="../wishlist/allow-all-unicode-passphrases/" title="Bug entry: “Allow all Unicode text strings as master passphrases”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2305 | 2661 |
<li> |
2306 | 2662 |
<p>Move all existing functionality into a subcommand, in anticipation of |
2307 | 2663 |
other passphrase derivation schemes, with different settings. |
... | ... |
@@ -2311,11 +2667,13 @@ even if <code>vault</code> is not installed. |
2311 | 2667 |
instead of globally. |
2312 | 2668 |
Automatically fall back to, and migrate, the old global settings file if |
2313 | 2669 |
no subsystem-specific configuration was found. |
2314 |
-(<a href="https://github.com/the-13th-letter/derivepassphrase/10">#10</a>)</p> |
|
2670 |
+→<a href="../wishlist/other-derivation-schemes/" title="Wish entry: “Consider implementing passphrase schemes other than vault's”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a> |
|
2671 |
+<a href="../wishlist/scheme-specific-cli-and-config/" title="Wish entry: “Move vault-specific command-line interface into a separate CLI subcommand and matching configuration file”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2315 | 2672 |
</li> |
2316 | 2673 |
<li> |
2317 |
-<p>Make <code>derivepassphrase_export</code> a subcommand: <code>derivepassphrase export</code>. |
|
2318 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/11">#11</a>)</p> |
|
2674 |
+<p>Make <code>derivepassphrase_export</code> a subcommand: <a href="../reference/derivepassphrase-export.1/"><code>derivepassphrase |
|
2675 |
+ export</code></a>. |
|
2676 |
+ →<a href="../wishlist/exporter-script-as-subcommand/" title="Wish entry: “Make the exporter a subcommand of derivepassphrase”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.06 1.93C7.17 1.92 5.33 3.74 6.17 6H3a2 2 0 0 0-2 2v2a1 1 0 0 0 1 1h9V8h2v3h9a1 1 0 0 0 1-1V8a2 2 0 0 0-2-2h-3.17C19 2.73 14.6.42 12.57 3.24L12 4l-.57-.78c-.63-.89-1.5-1.28-2.37-1.29M9 4c.89 0 1.34 1.08.71 1.71S8 5.89 8 5a1 1 0 0 1 1-1m6 0c.89 0 1.34 1.08.71 1.71S14 5.89 14 5a1 1 0 0 1 1-1M2 12v8a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-8h-9v8h-2v-8z"/></svg></span></a></p> |
|
2319 | 2677 |
</li> |
2320 | 2678 |
</ul> |
2321 | 2679 |
<h3 id="deprecated-in-v0.2.0">Deprecated<a class="headerlink" href="#deprecated-in-v0.2.0" title="Permanent link">¶</a></h3> |
... | ... |
@@ -2328,14 +2686,14 @@ no subsystem-specific configuration was found. |
2328 | 2686 |
<ul> |
2329 | 2687 |
<li>Do not crash upon selecting a key on the command-line if there already |
2330 | 2688 |
is a key stored in the configuration. |
2331 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/5">#5</a>)</li> |
|
2689 |
+ →<a href="../wishlist/one-time-key-override-fails/" title="Bug entry: “derivepassphrase -k fails when overriding the chosen key on the command-line”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2332 | 2690 |
<li>Create the configuration directory upon saving, if it does not yet |
2333 | 2691 |
exist. |
2334 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/6">#6</a>)</li> |
|
2692 |
+ →<a href="../wishlist/configuration-directory-must-exist/" title="Bug entry: “derivepassphrase --config requires configuration directory to exist”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2335 | 2693 |
<li>Isolate the tests properly and consistently from the user’s |
2336 | 2694 |
configuration, so that user configuration problems do not cause |
2337 | 2695 |
unrelated test failures. |
2338 |
- (<a href="https://github.com/the-13th-letter/derivepassphrase/8">#8</a>)</li> |
|
2696 |
+ →<a href="../wishlist/test-filesystem-isolation/" title="Bug entry: “Isolate tests properly from the filesystem”"><span class="twemoji"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M14 12h-4v-2h4m0 6h-4v-2h4m6-6h-2.81a6 6 0 0 0-1.82-1.96L17 4.41 15.59 3l-2.17 2.17a6 6 0 0 0-2.83 0L8.41 3 7 4.41l1.62 1.63C7.88 6.55 7.26 7.22 6.81 8H4v2h2.09c-.05.33-.09.66-.09 1v1H4v2h2v1c0 .34.04.67.09 1H4v2h2.81c1.04 1.79 2.97 3 5.19 3s4.15-1.21 5.19-3H20v-2h-2.09c.05-.33.09-.66.09-1v-1h2v-2h-2v-1c0-.34-.04-.67-.09-1H20z"/></svg></span></a></li> |
|
2339 | 2697 |
<li>Add an alternate MkDocs configuration for building the documentation in |
2340 | 2698 |
offline mode.</li> |
2341 | 2699 |
<li>Fix typing issues according to <code>mypy</code>’s strict mode.</li> |
... | ... |
@@ -2347,14 +2705,12 @@ no subsystem-specific configuration was found. |
2347 | 2705 |
distributions. |
2348 | 2706 |
(Previously, <code>sdist</code> contained VCS artifacts, and <code>wheel</code> was missing |
2349 | 2707 |
some paths.)</li> |
2350 |
-<li>Lint and reformat all code using <a href="https://pypi.org/package/ruff/">ruff</a>.</li> |
|
2351 |
-<li>Mention |
|
2352 |
- <a href="https://pypi.org/package/mkdocstrings-python/"><code>mkdocstrings-python</code></a> |
|
2353 |
- in the documentation’s page footer.</li> |
|
2708 |
+<li>Lint and reformat all code using <a href="https://pypi.org/project/ruff/">ruff</a>.</li> |
|
2709 |
+<li>Mention <a href="https://pypi.org/project/mkdocstrings-python/"><code>mkdocstrings-python</code></a> in the |
|
2710 |
+ documentation’s page footer.</li> |
|
2354 | 2711 |
<li>Remove JavaScript and external font loading from documentation website, |
2355 | 2712 |
so that the site works even in restricted browser settings.</li> |
2356 |
-<li>Set up a changelog, using |
|
2357 |
- <a href="https://pypi.org/package/towncrier">towncrier</a>.</li> |
|
2713 |
+<li>Set up a changelog, using <a href="https://pypi.org/project/towncrier/">towncrier</a>.</li> |
|
2358 | 2714 |
</ul> |
2359 | 2715 |
<h2 id="v0.1.1">0.1.1 (2024-07-14)<a class="headerlink" href="#v0.1.1" title="Permanent link">¶</a></h2> |
2360 | 2716 |
<h3 id="fixed-in-v0.1.1">Fixed<a class="headerlink" href="#fixed-in-v0.1.1" title="Permanent link">¶</a></h3> |
... | ... |
@@ -2370,6 +2726,16 @@ no subsystem-specific configuration was found. |
2370 | 2726 |
<ul> |
2371 | 2727 |
<li>Initial release.</li> |
2372 | 2728 |
</ul> |
2729 |
+<div class="footnote"> |
|
2730 |
+<hr /> |
|
2731 |
+<ol> |
|
2732 |
+<li id="fn:the-annoying-os"> |
|
2733 |
+<p>Hat tip—and apologies—to |
|
2734 |
+<a href="https://github.com/pawamoy/">Timothée Mazzucotelli (<code>@pawamoy</code>)</a> for |
|
2735 |
+the fitting terminology. <a class="footnote-backref" href="#fnref:the-annoying-os" title="Jump back to footnote 1 in the text">↩</a></p> |
|
2736 |
+</li> |
|
2737 |
+</ol> |
|
2738 |
+</div> |
|
2373 | 2739 |
|
2374 | 2740 |
|
2375 | 2741 |
|
... | ... |
@@ -2,206 +2,206 @@ |
2 | 2 |
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"> |
3 | 3 |
<url> |
4 | 4 |
<loc>https://the13thletter.info/derivepassphrase/0.x/</loc> |
5 |
- <lastmod>2025-06-14</lastmod> |
|
5 |
+ <lastmod>2025-06-18</lastmod> |
|
6 | 6 |
</url> |
7 | 7 |
<url> |
8 | 8 |
<loc>https://the13thletter.info/derivepassphrase/0.x/changelog/</loc> |
9 |
- <lastmod>2025-06-14</lastmod> |
|
9 |
+ <lastmod>2025-06-18</lastmod> |
|
10 | 10 |
</url> |
11 | 11 |
<url> |
12 | 12 |
<loc>https://the13thletter.info/derivepassphrase/0.x/pycompatibility/</loc> |
13 |
- <lastmod>2025-06-14</lastmod> |
|
13 |
+ <lastmod>2025-06-18</lastmod> |
|
14 | 14 |
</url> |
15 | 15 |
<url> |
16 | 16 |
<loc>https://the13thletter.info/derivepassphrase/0.x/upgrade-notes/</loc> |
17 |
- <lastmod>2025-06-14</lastmod> |
|
17 |
+ <lastmod>2025-06-18</lastmod> |
|
18 | 18 |
</url> |
19 | 19 |
<url> |
20 | 20 |
<loc>https://the13thletter.info/derivepassphrase/0.x/explanation/</loc> |
21 |
- <lastmod>2025-06-14</lastmod> |
|
21 |
+ <lastmod>2025-06-18</lastmod> |
|
22 | 22 |
</url> |
23 | 23 |
<url> |
24 | 24 |
<loc>https://the13thletter.info/derivepassphrase/0.x/explanation/faq-altered-versions/</loc> |
25 |
- <lastmod>2025-06-14</lastmod> |
|
25 |
+ <lastmod>2025-06-18</lastmod> |
|
26 | 26 |
</url> |
27 | 27 |
<url> |
28 | 28 |
<loc>https://the13thletter.info/derivepassphrase/0.x/explanation/faq-vault-interchangable-passphrases/</loc> |
29 |
- <lastmod>2025-06-14</lastmod> |
|
29 |
+ <lastmod>2025-06-18</lastmod> |
|
30 | 30 |
</url> |
31 | 31 |
<url> |
32 | 32 |
<loc>https://the13thletter.info/derivepassphrase/0.x/how-tos/</loc> |
33 |
- <lastmod>2025-06-14</lastmod> |
|
33 |
+ <lastmod>2025-06-18</lastmod> |
|
34 | 34 |
</url> |
35 | 35 |
<url> |
36 | 36 |
<loc>https://the13thletter.info/derivepassphrase/0.x/how-tos/ssh-key/</loc> |
37 |
- <lastmod>2025-06-14</lastmod> |
|
37 |
+ <lastmod>2025-06-18</lastmod> |
|
38 | 38 |
</url> |
39 | 39 |
<url> |
40 | 40 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/</loc> |
41 |
- <lastmod>2025-06-14</lastmod> |
|
41 |
+ <lastmod>2025-06-18</lastmod> |
|
42 | 42 |
</url> |
43 | 43 |
<url> |
44 | 44 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase-export-vault.1/</loc> |
45 |
- <lastmod>2025-06-14</lastmod> |
|
45 |
+ <lastmod>2025-06-18</lastmod> |
|
46 | 46 |
</url> |
47 | 47 |
<url> |
48 | 48 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase-export.1/</loc> |
49 |
- <lastmod>2025-06-14</lastmod> |
|
49 |
+ <lastmod>2025-06-18</lastmod> |
|
50 | 50 |
</url> |
51 | 51 |
<url> |
52 | 52 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase-vault.1/</loc> |
53 |
- <lastmod>2025-06-14</lastmod> |
|
53 |
+ <lastmod>2025-06-18</lastmod> |
|
54 | 54 |
</url> |
55 | 55 |
<url> |
56 | 56 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.1/</loc> |
57 |
- <lastmod>2025-06-14</lastmod> |
|
57 |
+ <lastmod>2025-06-18</lastmod> |
|
58 | 58 |
</url> |
59 | 59 |
<url> |
60 | 60 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase._internals.cli_helpers/</loc> |
61 |
- <lastmod>2025-06-14</lastmod> |
|
61 |
+ <lastmod>2025-06-18</lastmod> |
|
62 | 62 |
</url> |
63 | 63 |
<url> |
64 | 64 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase._internals.cli_machinery/</loc> |
65 |
- <lastmod>2025-06-14</lastmod> |
|
65 |
+ <lastmod>2025-06-18</lastmod> |
|
66 | 66 |
</url> |
67 | 67 |
<url> |
68 | 68 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase._internals.cli_messages/</loc> |
69 |
- <lastmod>2025-06-14</lastmod> |
|
69 |
+ <lastmod>2025-06-18</lastmod> |
|
70 | 70 |
</url> |
71 | 71 |
<url> |
72 | 72 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase._types/</loc> |
73 |
- <lastmod>2025-06-14</lastmod> |
|
73 |
+ <lastmod>2025-06-18</lastmod> |
|
74 | 74 |
</url> |
75 | 75 |
<url> |
76 | 76 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.cli/</loc> |
77 |
- <lastmod>2025-06-14</lastmod> |
|
77 |
+ <lastmod>2025-06-18</lastmod> |
|
78 | 78 |
</url> |
79 | 79 |
<url> |
80 | 80 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.exporter/</loc> |
81 |
- <lastmod>2025-06-14</lastmod> |
|
81 |
+ <lastmod>2025-06-18</lastmod> |
|
82 | 82 |
</url> |
83 | 83 |
<url> |
84 | 84 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.sequin/</loc> |
85 |
- <lastmod>2025-06-14</lastmod> |
|
85 |
+ <lastmod>2025-06-18</lastmod> |
|
86 | 86 |
</url> |
87 | 87 |
<url> |
88 | 88 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.ssh_agent/</loc> |
89 |
- <lastmod>2025-06-14</lastmod> |
|
89 |
+ <lastmod>2025-06-18</lastmod> |
|
90 | 90 |
</url> |
91 | 91 |
<url> |
92 | 92 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/derivepassphrase.vault/</loc> |
93 |
- <lastmod>2025-06-14</lastmod> |
|
93 |
+ <lastmod>2025-06-18</lastmod> |
|
94 | 94 |
</url> |
95 | 95 |
<url> |
96 | 96 |
<loc>https://the13thletter.info/derivepassphrase/0.x/reference/prerequisites-ssh-key/</loc> |
97 |
- <lastmod>2025-06-14</lastmod> |
|
97 |
+ <lastmod>2025-06-18</lastmod> |
|
98 | 98 |
</url> |
99 | 99 |
<url> |
100 | 100 |
<loc>https://the13thletter.info/derivepassphrase/0.x/tutorials/</loc> |
101 |
- <lastmod>2025-06-14</lastmod> |
|
101 |
+ <lastmod>2025-06-18</lastmod> |
|
102 | 102 |
</url> |
103 | 103 |
<url> |
104 | 104 |
<loc>https://the13thletter.info/derivepassphrase/0.x/tutorials/basic-setup-passphrase/</loc> |
105 |
- <lastmod>2025-06-14</lastmod> |
|
105 |
+ <lastmod>2025-06-18</lastmod> |
|
106 | 106 |
</url> |
107 | 107 |
<url> |
108 | 108 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/</loc> |
109 |
- <lastmod>2025-06-14</lastmod> |
|
109 |
+ <lastmod>2025-06-18</lastmod> |
|
110 | 110 |
</url> |
111 | 111 |
<url> |
112 | 112 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/allow-all-unicode-passphrases/</loc> |
113 |
- <lastmod>2025-06-14</lastmod> |
|
113 |
+ <lastmod>2025-06-18</lastmod> |
|
114 | 114 |
</url> |
115 | 115 |
<url> |
116 | 116 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/amend-vault-config/</loc> |
117 |
- <lastmod>2025-06-14</lastmod> |
|
117 |
+ <lastmod>2025-06-18</lastmod> |
|
118 | 118 |
</url> |
119 | 119 |
<url> |
120 | 120 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/better-error-messages/</loc> |
121 |
- <lastmod>2025-06-14</lastmod> |
|
121 |
+ <lastmod>2025-06-18</lastmod> |
|
122 | 122 |
</url> |
123 | 123 |
<url> |
124 | 124 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/concurrency-audit/</loc> |
125 |
- <lastmod>2025-06-14</lastmod> |
|
125 |
+ <lastmod>2025-06-18</lastmod> |
|
126 | 126 |
</url> |
127 | 127 |
<url> |
128 | 128 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/concurrency-testing-in-test-suite/</loc> |
129 |
- <lastmod>2025-06-14</lastmod> |
|
129 |
+ <lastmod>2025-06-18</lastmod> |
|
130 | 130 |
</url> |
131 | 131 |
<url> |
132 | 132 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/configuration-directory-must-exist/</loc> |
133 |
- <lastmod>2025-06-14</lastmod> |
|
133 |
+ <lastmod>2025-06-18</lastmod> |
|
134 | 134 |
</url> |
135 | 135 |
<url> |
136 | 136 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/conventional-configurable-text-styling/</loc> |
137 |
- <lastmod>2025-06-14</lastmod> |
|
137 |
+ <lastmod>2025-06-18</lastmod> |
|
138 | 138 |
</url> |
139 | 139 |
<url> |
140 | 140 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/export-vault-formats/</loc> |
141 |
- <lastmod>2025-06-14</lastmod> |
|
141 |
+ <lastmod>2025-06-18</lastmod> |
|
142 | 142 |
</url> |
143 | 143 |
<url> |
144 | 144 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/exporter-script-as-subcommand/</loc> |
145 |
- <lastmod>2025-06-14</lastmod> |
|
145 |
+ <lastmod>2025-06-18</lastmod> |
|
146 | 146 |
</url> |
147 | 147 |
<url> |
148 | 148 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/fail-gracefully-without-af-unix/</loc> |
149 |
- <lastmod>2025-06-14</lastmod> |
|
149 |
+ <lastmod>2025-06-18</lastmod> |
|
150 | 150 |
</url> |
151 | 151 |
<url> |
152 | 152 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/falsy-vault-config-values/</loc> |
153 |
- <lastmod>2025-06-14</lastmod> |
|
153 |
+ <lastmod>2025-06-18</lastmod> |
|
154 | 154 |
</url> |
155 | 155 |
<url> |
156 | 156 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/no-stdlib-module-names/</loc> |
157 |
- <lastmod>2025-06-14</lastmod> |
|
157 |
+ <lastmod>2025-06-18</lastmod> |
|
158 | 158 |
</url> |
159 | 159 |
<url> |
160 | 160 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/one-time-key-override-fails/</loc> |
161 |
- <lastmod>2025-06-14</lastmod> |
|
161 |
+ <lastmod>2025-06-18</lastmod> |
|
162 | 162 |
</url> |
163 | 163 |
<url> |
164 | 164 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/other-derivation-schemes/</loc> |
165 |
- <lastmod>2025-06-14</lastmod> |
|
165 |
+ <lastmod>2025-06-18</lastmod> |
|
166 | 166 |
</url> |
167 | 167 |
<url> |
168 | 168 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/pretty-print-json/</loc> |
169 |
- <lastmod>2025-06-14</lastmod> |
|
169 |
+ <lastmod>2025-06-18</lastmod> |
|
170 | 170 |
</url> |
171 | 171 |
<url> |
172 | 172 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/print-service-notes-above/</loc> |
173 |
- <lastmod>2025-06-14</lastmod> |
|
173 |
+ <lastmod>2025-06-18</lastmod> |
|
174 | 174 |
</url> |
175 | 175 |
<url> |
176 | 176 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/print-service-notes/</loc> |
177 |
- <lastmod>2025-06-14</lastmod> |
|
177 |
+ <lastmod>2025-06-18</lastmod> |
|
178 | 178 |
</url> |
179 | 179 |
<url> |
180 | 180 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/remove-pageant-build-info-check/</loc> |
181 |
- <lastmod>2025-06-14</lastmod> |
|
181 |
+ <lastmod>2025-06-18</lastmod> |
|
182 | 182 |
</url> |
183 | 183 |
<url> |
184 | 184 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/report-build-flags-and-features/</loc> |
185 |
- <lastmod>2025-06-14</lastmod> |
|
185 |
+ <lastmod>2025-06-18</lastmod> |
|
186 | 186 |
</url> |
187 | 187 |
<url> |
188 | 188 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/scheme-specific-cli-and-config/</loc> |
189 |
- <lastmod>2025-06-14</lastmod> |
|
189 |
+ <lastmod>2025-06-18</lastmod> |
|
190 | 190 |
</url> |
191 | 191 |
<url> |
192 | 192 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/single-toplevel-module/</loc> |
193 |
- <lastmod>2025-06-14</lastmod> |
|
193 |
+ <lastmod>2025-06-18</lastmod> |
|
194 | 194 |
</url> |
195 | 195 |
<url> |
196 | 196 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/test-filesystem-isolation/</loc> |
197 |
- <lastmod>2025-06-14</lastmod> |
|
197 |
+ <lastmod>2025-06-18</lastmod> |
|
198 | 198 |
</url> |
199 | 199 |
<url> |
200 | 200 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/test-suite-isolated-ssh-agent/</loc> |
201 |
- <lastmod>2025-06-14</lastmod> |
|
201 |
+ <lastmod>2025-06-18</lastmod> |
|
202 | 202 |
</url> |
203 | 203 |
<url> |
204 | 204 |
<loc>https://the13thletter.info/derivepassphrase/0.x/wishlist/windows-ssh-agent-support/</loc> |
205 |
- <lastmod>2025-06-14</lastmod> |
|
205 |
+ <lastmod>2025-06-18</lastmod> |
|
206 | 206 |
</url> |
207 | 207 |
</urlset> |
208 | 208 |
\ No newline at end of file |
... | ... |
@@ -32,3 +32,12 @@ a.fixed { |
32 | 32 |
font-style: normal; |
33 | 33 |
text-decoration: line-through; |
34 | 34 |
} |
35 |
+ |
|
36 |
+.md-typeset div.admonition.abstract .emojione, |
|
37 |
+.md-typeset div.admonition.abstract .gemoji, |
|
38 |
+.md-typeset div.admonition.abstract .twemoji, |
|
39 |
+.md-typeset a[href^="wishlist/"] .emojione, |
|
40 |
+.md-typeset a[href^="wishlist/"] .gemoji, |
|
41 |
+.md-typeset a[href^="wishlist/"] .twemoji { |
|
42 |
+ vertical-align: middle; |
|
43 |
+} |
|
35 | 44 |