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 |