]> git.immae.eu Git - perso/Immae/Projets/Cryptomonnaies/BIP39.git/blame - src/index.html
Release v0.3.0
[perso/Immae/Projets/Cryptomonnaies/BIP39.git] / src / index.html
CommitLineData
ebd8d4e8
IC
1<!DOCTYPE html>
2<html>
3 <head lang="en">
4 <meta charset="utf-8" />
5 <title>BIP39 - Mnemonic Code</title>
cee442b1 6 <link rel="stylesheet" href="css/bootstrap.min.css">
ebd8d4e8
IC
7 <meta content="Mnemonic code for generating deterministic keys" name="description"/>
8 <meta content="width=device-width, initial-scale=1.0" name="viewport" />
9 <meta content="bitcoin mnemonic converter" name="description" />
b630f83d 10 <meta content="Ian Coleman" name="author" />
18f16009 11 <link type="image/x-icon" rel="icon" href="data:image/x-icon;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQEAYAAABPYyMiAAAABmJLR0T///////8JWPfcAAAACXBIWXMAAABIAAAASABGyWs+AAAAF0lEQVRIx2NgGAWjYBSMglEwCkbBSAcACBAAAeaR9cIAAAAASUVORK5CYII=" />
ebd8d4e8
IC
12
13 <style>
f52dcdbd
IC
14 body {
15 padding-bottom: 32px;
16 }
d198865f
IC
17 .form-control[readonly] {
18 cursor: text;
dd566a1e 19 }
ebd8d4e8
IC
20 .feedback-container {
21 position: fixed;
22 top: 0;
23 width: 100%;
24 text-align: center;
25 z-index: 4;
26 }
27 .feedback {
28 display: table;
29 padding: 0.5em 1em;
30 background-color: orange;
31 margin: 0 auto;
32 font-size: 2em;
33 color: #444;
34 border: 2px solid #555;
35 border-top: 0;
36 border-bottom-left-radius: 20px 20px;
37 border-bottom-right-radius: 20px 20px;
38 }
55a9e51a
IC
39 .no-border {
40 border: 0;
41 box-shadow: inset 0 1px 1px rgba(0,0,0,.0);
42 -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.0);
43 }
5ee7bb9e
IC
44 .phrase {
45 word-break: keep-all;
46 }
0a84fe6a 47 .generate-container .strength {
b0818b31
IC
48 /* override mobile width from bootstrap */
49 width: auto!important;
50 display: inline-block;
51 }
60599f7a 52 .languages a {
7c31e3cd
IC
53 padding-left: 10px;
54 }
60599f7a
IC
55 .languages a:nth-of-type(1) {
56 margin-left: -12px;
57 padding-left: 0;
58 }
d737abf6
IC
59 .monospace {
60 font-family: monospace;
61 }
0a84fe6a
IC
62 .entropy-container .filtered,
63 .entropy-container .binary {
64 word-wrap: break-word;
65 }
66 .entropy-container li {
67 padding-bottom: 5px;
68 }
b54c1218 69 .card-suit {
b2d61f56 70 font-size: 19px;
b54c1218
IC
71 line-height: 0;
72 }
73 .card-suit.club {
74 color: #009F00;
75 }
76 .card-suit.diamond {
77 color: #3D5DC4;
78 }
79 .card-suit.heart {
80 color: #F00;
81 }
82 .card-suit.spade {
83 color: #000;
84 }
e00964cc
IC
85 .qr-container {
86 position: fixed;
87 top: 0;
88 right: 0;
89 text-align: center;
90 background-color: #FFF;
91 border: 1px solid #CCC;
92 }
93 .qr-image {
94 margin: 5px;
95 }
97811c29
IC
96 .qr-hint,
97 .qr-warning {
e00964cc 98 padding: 2px;
97811c29 99 max-width: 150px;
e00964cc 100 }
e5abab42
IC
101 .more-info {
102 cursor: help;
103 border-bottom: 1px dashed #000;
104 text-decoration: none;
105 }
8b18bdbb
IC
106 .version {
107 position: absolute;
108 top: 5px;
109 right: 5px;
110 }
ebd8d4e8
IC
111 </style>
112 </head>
113 <body>
114 <div class="container">
115
116 <h1 class="text-center">Mnemonic Code Converter</h1>
cf6c2044 117 <p class="version">v0.3.0</p>
ebd8d4e8
IC
118 <hr>
119 <div class="row">
120 <div class="col-md-12">
d4779799 121 <h2>Mnemonic</h2>
ebd8d4e8 122 <form class="form-horizontal" role="form">
ebd8d4e8 123 <div class="form-group">
c6624d51
IC
124 <div class="col-sm-2"></div>
125 <div class="col-sm-10">
fb00a22d
IC
126 <p>You can enter an existing BIP39 mnemonic, or generate a new random one. Typing your own twelve words will probably not work how you expect, since the words require a particular structure (the last word is a checksum).</p>
127 <p>
60599f7a
IC
128 For more info see the
129 <a href="https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki" target="_blank">BIP39 spec</a>.
130 </p>
c6624d51
IC
131 </div>
132 </div>
133 <div class="form-group generate-container">
b0818b31 134 <label class="col-sm-2 control-label"></label>
ebd8d4e8 135 <div class="col-sm-10">
b0818b31
IC
136 <div class="form-inline">
137 <div class="input-group-inline">
fb00a22d 138 <span>Generate a random mnemonic, or enter your own below</span>:
b0818b31 139 <button class="btn generate">Generate</button>
b0818b31
IC
140 <select id="strength" class="strength form-control">
141 <option value="3">3</option>
142 <option value="6">6</option>
143 <option value="9">9</option>
144 <option value="12">12</option>
145 <option value="15" selected>15</option>
146 <option value="18">18</option>
147 <option value="21">21</option>
148 <option value="24">24</option>
149 </select>
fb00a22d 150 <span>words</span>
b0818b31
IC
151 </div>
152 </div>
ebd8d4e8 153 </div>
7c31e3cd 154 </div>
c6624d51 155 <div class="entropy-container hidden">
0a84fe6a 156 <div class="form-group text-danger">
fb00a22d 157 <label class="col-sm-2 control-label">Warning</label>
0a84fe6a 158 <div class="col-sm-10 form-control-static">
fb00a22d
IC
159 <span>Entropy is an advanced feature. Your mnemonic may be insecure if this feature is used incorrectly.</span>
160 <a href="#entropy-notes">Read more</a>
439f0e25 161 </div>
1cf1bbaf 162 </div>
0a84fe6a 163 <div class="form-group">
fb00a22d 164 <label for="entropy" class="col-sm-2 control-label">Entropy</label>
0a84fe6a 165 <div class="col-sm-7">
fb00a22d 166 <textarea id="entropy" rows="2" class="entropy form-control" placeholder="Accepts either binary, base 6, 6-sided dice, base 10, hexadecimal or cards"></textarea>
ee0981f1
IC
167 <div class="row filter-warning text-danger hidden">
168 <p class="col-sm-12">
169 <strong>
170 Some characters have been discarded
171 </strong>
172 </p>
173 </div>
a3a61b68 174 <div class="row">
fb00a22d 175 <label class="col-sm-3 control-label"><span class="more-info" title="Based on estimates from zxcvbn using Filtered Entropy">Time To Crack</span></label>
20f459ce 176 <div class="crack-time col-sm-3 form-control-static"></div>
fb00a22d 177 <label class="col-sm-3 control-label">Event Count</label>
a3a61b68
IC
178 <div class="event-count col-sm-3 form-control-static"></div>
179 </div>
180 <div class="row">
fb00a22d 181 <label class="col-sm-3 control-label">Entropy Type</label>
a3a61b68 182 <div class="type col-sm-3 form-control-static"></div>
fb00a22d 183 <label class="col-sm-3 control-label">Bits Per Event</label>
a3a61b68
IC
184 <div class="bits-per-event col-sm-3 form-control-static"></div>
185 </div>
186 <div class="row">
fb00a22d 187 <label class="col-sm-3 control-label">Raw Entropy Words</label>
a3a61b68 188 <div class="word-count col-sm-3 form-control-static"></div>
fb00a22d 189 <label class="col-sm-3 control-label"><span class="more-info" title="Total bits of entropy may be less than indicated if any entropy event uses a weak source.">Total Bits</span></label>
a3a61b68
IC
190 <div class="bits col-sm-3 form-control-static"></div>
191 </div>
fb00a22d 192 <label class="col-sm-3 control-label">Filtered Entropy</label>
0a84fe6a 193 <div class="filtered col-sm-9 form-control-static"></div>
fb00a22d 194 <label class="col-sm-3 control-label">Raw Binary</label>
0a84fe6a 195 <div class="binary col-sm-9 form-control-static"></div>
fb00a22d 196 <label class="col-sm-3 control-label">Mnemonic Length</label>
0a84fe6a 197 <div class="col-sm-9">
1cf1bbaf 198 <select class="mnemonic-length form-control">
fb00a22d
IC
199 <option value="raw" selected>Use Raw Entropy (3 words per 32 bits)</option>
200 <option value="12">12 <span>Words</span></option>
201 <option value="15">15 <span>Words</option>
202 <option value="18">18 <span>Words</span></option>
203 <option value="21">21 <span>Words</span></option>
204 <option value="24">24 <span>Words</span></option>
1cf1bbaf 205 </select>
c6624d51 206 </div>
1cf1bbaf 207 </div>
0a84fe6a 208 <div class="col-sm-3">
fb00a22d 209 <p>Valid entropy values include:</p>
0a84fe6a 210 <ul>
fb00a22d
IC
211 <li><strong>Binary</strong> [0-1]<br>101010011</li>
212 <li><strong>Base 6</strong> [0-5]<br>123434014</li>
213 <li><strong>Dice</strong> [1-6]<br>62535634</li>
214 <li><strong>Base 10</strong> [0-9]<br>90834528</li>
215 <li><strong>Hex</strong> [0-9A-F]<br>4187a8bfd9</li>
216 <li><strong>Card</strong> [A2-9TJQK][CDHS]<br>ahqs9dtc</li>
0a84fe6a
IC
217 </ul>
218 </div>
c6624d51
IC
219 </div>
220 </div>
221 <div class="form-group">
222 <div class="col-sm-2"></div>
223 <div class="col-sm-10 checkbox">
224 <label>
225 <input type="checkbox" class="use-entropy">
fb00a22d 226 <span>Supply my own source of entropy</span>
c6624d51
IC
227 </label>
228 </div>
229 </div>
230 <div class="form-group">
fb00a22d 231 <label class="col-sm-2 control-label">Mnemonic Language</label>
7c31e3cd 232 <div class="col-sm-10 languages">
60599f7a
IC
233 <div class="form-control no-border">
234 <a href="#english">English</a>
235 <a href="#japanese" title="Japanese">日本語</a>
236 <a href="#spanish" title="Spanish">Español</a>
237 <a href="#chinese_simplified" title="Chinese (Simplified)">中文(简体)</a>
238 <a href="#chinese_traditional" title="Chinese (Traditional)">中文(繁體)</a>
239 <a href="#french" title="French">Français</a>
240 <a href="#italian" title="Italian">Italiano</a>
241 </div>
7c31e3cd 242 </div>
ebd8d4e8
IC
243 </div>
244 <div class="form-group">
fb00a22d 245 <label for="phrase" class="col-sm-2 control-label">BIP39 Mnemonic</label>
ebd8d4e8 246 <div class="col-sm-10">
e00964cc 247 <textarea id="phrase" class="phrase form-control" data-show-qr></textarea>
ebd8d4e8
IC
248 </div>
249 </div>
1abcc511 250 <div class="form-group">
fb00a22d 251 <label for="passphrase" class="col-sm-2 control-label">BIP39 Passphrase (optional)</label>
1abcc511
PR
252 <div class="col-sm-10">
253 <textarea id="passphrase" class="passphrase form-control"></textarea>
254 </div>
255 </div>
3e0ed16a 256 <div class="form-group">
fb00a22d 257 <label for="seed" class="col-sm-2 control-label">BIP39 Seed</label>
3e0ed16a 258 <div class="col-sm-10">
e00964cc 259 <textarea id="seed" class="seed form-control" readonly="readonly" data-show-qr></textarea>
3e0ed16a
KK
260 </div>
261 </div>
4d457a38 262 <div class="form-group">
fb00a22d 263 <label for="network-phrase" class="col-sm-2 control-label">Coin</label>
4d457a38
IC
264 <div class="col-sm-10">
265 <select id="network-phrase" class="network form-control">
7f15cb6e 266 <!-- populated by javascript -->
4d457a38
IC
267 </select>
268 </div>
269 </div>
ebd8d4e8 270 <div class="form-group">
fb00a22d 271 <label for="root-key" class="col-sm-2 control-label">BIP32 Root Key</label>
ebd8d4e8 272 <div class="col-sm-10">
e00964cc 273 <textarea id="root-key" class="root-key form-control" data-show-qr></textarea>
ebd8d4e8
IC
274 </div>
275 </div>
3abab9b0 276 <div class="form-group litecoin-ltub-container hidden">
fb00a22d 277 <label for="litecoin-use-ltub" class="col-sm-2 control-label">Prefixes</label>
3abab9b0
IC
278 <div class="col-sm-10 checkbox">
279 <label>
1c2b8c6b 280 <input type="checkbox" id="litecoin-use-ltub" class="litecoin-use-ltub" checked="checked">
3abab9b0
IC
281 Use <code>Ltpv / Ltub</code> instead of <code>xprv / xpub</code>
282 </label>
283 </div>
284 </div>
ebd8d4e8
IC
285 </form>
286 </div>
287 </div>
288
289 <hr>
290
291 <div class="row">
292 <div class="col-md-12">
293 <h2>Derivation Path</h2>
294 <ul class="derivation-type nav nav-tabs" role="tablist">
3b40653f 295 <li id="bip32-tab">
23d4a0f1
IC
296 <a href="#bip32" role="tab" data-toggle="tab">BIP32</a>
297 </li>
33b3dd47
IC
298 <li id="bip44-tab" class="active">
299 <a href="#bip44" role="tab" data-toggle="tab">BIP44</a>
300 </li>
6c08f364
IC
301 <li id="bip49-tab">
302 <a href="#bip49" role="tab" data-toggle="tab">BIP49</a>
303 </li>
c49e8812
IC
304 <li id="bip141-tab">
305 <a href="#bip141" role="tab" data-toggle="tab">BIP141</a>
306 </li>
ebd8d4e8
IC
307 </ul>
308 <div class="derivation-type tab-content">
55a9e51a 309 <div id="bip44" class="tab-pane active">
ebd8d4e8
IC
310 <form class="form-horizontal" role="form">
311 <br>
312 <div class="col-sm-2"></div>
313 <div class="col-sm-10">
fb00a22d 314 <p>
60599f7a
IC
315 For more info see the
316 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki" target="_blank">BIP44 spec</a>.
317 </p>
ebd8d4e8
IC
318 </div>
319 <div class="form-group">
320 <label for="purpose" class="col-sm-2 control-label">
fb00a22d 321 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#purpose" target="_blank">Purpose</a>
ebd8d4e8
IC
322 </label>
323 <div class="col-sm-10">
684624b5 324 <input id="purpose" type="text" class="purpose form-control" value="44" readonly>
ebd8d4e8
IC
325 </div>
326 </div>
327 <div class="form-group">
328 <label for="coin" class="col-sm-2 control-label">
fb00a22d 329 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#registered-coin-types" target="_blank">Coin</a>
ebd8d4e8
IC
330 </label>
331 <div class="col-sm-10">
684624b5 332 <input id="coin" type="text" class="coin form-control" value="0" readonly>
ebd8d4e8
IC
333 </div>
334 </div>
335 <div class="form-group">
336 <label for="account" class="col-sm-2 control-label">
fb00a22d 337 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#account" target="_blank">Account</a>
ebd8d4e8
IC
338 </label>
339 <div class="col-sm-10">
340 <input id="account" type="text" class="account form-control" value="0">
341 </div>
342 </div>
343 <div class="form-group">
344 <label for="change" class="col-sm-2 control-label">
fb00a22d 345 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#change" target="_blank">External / Internal</a>
ebd8d4e8
IC
346 </label>
347 <div class="col-sm-10">
348 <input id="change" type="text" class="change form-control" value="0">
349 </div>
350 </div>
c554e6ff
IC
351 <div class="form-group">
352 <label class="col-sm-2 control-label">
353 </label>
354 <div class="col-sm-10">
fb00a22d 355 <p>The account extended keys can be used for importing to most BIP44 compatible wallets, such as mycelium or electrum.</p>
c554e6ff
IC
356 </div>
357 </div>
358 <div class="form-group">
359 <label for="account-xprv" class="col-sm-2 control-label">
fb00a22d 360 <span>Account Extended Private Key</span>
c554e6ff
IC
361 </label>
362 <div class="col-sm-10">
363 <textarea id="account-xprv" type="text" class="account-xprv form-control" readonly data-show-qr></textarea>
364 </div>
365 </div>
366 <div class="form-group">
367 <label for="account-xpub" class="col-sm-2 control-label">
fb00a22d 368 <span>Account Extended Public Key</span>
c554e6ff
IC
369 </label>
370 <div class="col-sm-10">
371 <textarea id="account-xpub" type="text" class="account-xpub form-control" readonly data-show-qr></textarea>
372 </div>
373 </div>
374 <div class="form-group">
375 <label class="col-sm-2 control-label">
376 </label>
377 <div class="col-sm-10">
fb00a22d 378 <p>The BIP32 derivation path and extended keys are the basis for the derived addresses.</p>
c554e6ff
IC
379 </div>
380 </div>
ebd8d4e8 381 <div class="form-group">
fb00a22d 382 <label for="bip44-path" class="col-sm-2 control-label">BIP32 Derivation Path</label>
ebd8d4e8 383 <div class="col-sm-10">
d198865f 384 <input id="bip44-path" type="text" class="path form-control" value="m/44'/0'/0'/0" readonly="readonly">
ebd8d4e8
IC
385 </div>
386 </div>
387 </form>
388 </div>
389 <div id="bip32" class="tab-pane">
390 <form class="form-horizontal" role="form">
391 <br>
392 <div class="col-sm-2"></div>
393 <div class="col-sm-10">
fb00a22d 394 <p>
60599f7a
IC
395 For more info see the
396 <a href="https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki" target="_blank">BIP32 spec</a>
397 </p>
ebd8d4e8 398 </div>
a2e3e819 399 <div class="form-group">
fb00a22d 400 <label for="bip32-client" class="col-sm-2 control-label">Client</label>
a2e3e819 401 <div class="col-sm-10">
29bf60f5
IC
402 <select id="bip32-client" class="client form-control">
403 <option value="custom">Custom derivation path</option>
a2e3e819
IC
404 <!-- populated by javascript -->
405 </select>
406 </div>
407 </div>
ebd8d4e8 408 <div class="form-group">
fb00a22d 409 <label for="bip32-path" class="col-sm-2 control-label">BIP32 Derivation Path</label>
ebd8d4e8
IC
410 <div class="col-sm-10">
411 <input id="bip32-path" type="text" class="path form-control" value="m/0">
412 </div>
413 </div>
146e089e
IC
414 <div class="form-group">
415 <div class="col-sm-2"></div>
416 <label class="col-sm-10">
417 <input class="hardened-addresses" type="checkbox">
fb00a22d 418 <span>Use hardened addresses</span>
146e089e
IC
419 </label>
420 </div>
8786746b 421 <div class="form-group">
fb00a22d 422 <label for="core-path" class="col-sm-2 control-label">Bitcoin Core</label>
8786746b 423 <div class="col-sm-10">
fb00a22d 424 <p class="form-control no-border">
8786746b 425 Use path <code>m/0'/0'</code> with hardened addresses.
ea12c8a9 426 </p>
fb00a22d 427 <p class="form-control no-border">
60599f7a
IC
428 For more info see the
429 <a href="https://github.com/bitcoin/bitcoin/pull/8035" target="_blank">Bitcoin Core BIP32 implementation</a>
8786746b
IC
430 </p>
431 </div>
432 </div>
aa51da11 433 <div class="form-group">
fb00a22d 434 <label for="core-path" class="col-sm-2 control-label">Multibit</label>
aa51da11
IC
435 <div class="col-sm-10">
436 <p class="form-control no-border">
fb00a22d 437 <span>Use path <code>m/0'/0</code>.</span>
ea12c8a9
IC
438 </p>
439 <p class="form-control no-border">
fb00a22d 440 <span>For more info see</span>
6ee4fb7d 441 <a href="https://multibit.org/" target="_blank">MultiBit HD</a>
aa51da11 442 </p>
6ee4fb7d
IC
443 </div>
444 </div>
445 <div class="form-group">
fb00a22d 446 <label class="col-sm-2 control-label">Block Explorers</label>
6ee4fb7d 447 <div class="col-sm-10">
3f363a42 448 <p class="form-control no-border">
fb00a22d
IC
449 <span>Use path <code>m/44'/0'/0'</code>.</span>
450 <span>Only enter the <code>xpub</code> extended key into block explorer search fields, never the <code>xprv</code> key.</span>
3f363a42
AG
451 </p>
452 <p class="form-control no-border">
fb00a22d 453 <span>Can be used with</span>:
6ee4fb7d 454 <a href="https://blockchain.info/" target="_blank">blockchain.info</a>
3f363a42 455 </p>
aa51da11
IC
456 </div>
457 </div>
ebd8d4e8
IC
458 </form>
459 </div>
6c08f364
IC
460 <div id="bip49" class="tab-pane">
461 <form class="form-horizontal" role="form">
462 <br>
463 <div class="unavailable hidden">
464 <div class="form-group">
465 <div class="col-sm-2"></div>
466 <div class="col-sm-10">
fb00a22d 467 <p>BIP49 is unavailable for this coin.</p>
6c08f364
IC
468 </div>
469 </div>
470 </div>
471 <div class="available">
472 <div class="col-sm-2"></div>
473 <div class="col-sm-10">
fb00a22d 474 <p>
6c08f364
IC
475 For more info see the
476 <a href="https://github.com/bitcoin/bips/blob/master/bip-0049.mediawiki" target="_blank">BIP49 spec</a>.
477 </p>
478 </div>
479 <div class="form-group">
480 <label for="purpose" class="col-sm-2 control-label">
fb00a22d 481 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#purpose" target="_blank">Purpose</a>
6c08f364
IC
482 </label>
483 <div class="col-sm-10">
484 <input id="purpose" type="text" class="purpose form-control" value="49" readonly>
485 </div>
486 </div>
487 <div class="form-group">
488 <label for="coin" class="col-sm-2 control-label">
fb00a22d 489 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#registered-coin-types" target="_blank">Coin</a>
6c08f364
IC
490 </label>
491 <div class="col-sm-10">
492 <input id="coin" type="text" class="coin form-control" value="0" readonly>
493 </div>
494 </div>
495 <div class="form-group">
496 <label for="account" class="col-sm-2 control-label">
fb00a22d 497 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#account" target="_blank">Account</a>
6c08f364
IC
498 </label>
499 <div class="col-sm-10">
500 <input id="account" type="text" class="account form-control" value="0">
501 </div>
502 </div>
503 <div class="form-group">
504 <label for="change" class="col-sm-2 control-label">
fb00a22d 505 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki#change" target="_blank">External / Internal</a>
6c08f364
IC
506 </label>
507 <div class="col-sm-10">
508 <input id="change" type="text" class="change form-control" value="0">
509 </div>
510 </div>
511 <div class="form-group">
512 <label class="col-sm-2 control-label">
513 </label>
514 <div class="col-sm-10">
fb00a22d 515 <p>The account extended keys can be used for importing to most BIP49 compatible wallets.</p>
6c08f364
IC
516 </div>
517 </div>
518 <div class="form-group">
519 <label for="account-xprv" class="col-sm-2 control-label">
fb00a22d 520 <span>Account Extended Private Key</span>
6c08f364
IC
521 </label>
522 <div class="col-sm-10">
523 <textarea id="account-xprv" type="text" class="account-xprv form-control" readonly data-show-qr></textarea>
524 </div>
525 </div>
526 <div class="form-group">
527 <label for="account-xpub" class="col-sm-2 control-label">
fb00a22d 528 <span>Account Extended Public Key</span>
6c08f364
IC
529 </label>
530 <div class="col-sm-10">
531 <textarea id="account-xpub" type="text" class="account-xpub form-control" readonly data-show-qr></textarea>
532 </div>
533 </div>
534 <div class="form-group">
535 <label class="col-sm-2 control-label">
536 </label>
537 <div class="col-sm-10">
fb00a22d 538 <p>The BIP32 derivation path and extended keys are the basis for the derived addresses.</p>
6c08f364
IC
539 </div>
540 </div>
541 <div class="form-group">
fb00a22d 542 <label for="bip49-path" class="col-sm-2 control-label">BIP32 Derivation Path</label>
6c08f364
IC
543 <div class="col-sm-10">
544 <input id="bip49-path" type="text" class="path form-control" value="m/49'/0'/0'/0" readonly="readonly">
545 </div>
546 </div>
547 </div>
548 </form>
549 </div>
c49e8812
IC
550 <div id="bip141" class="tab-pane">
551 <form class="form-horizontal" role="form">
552 <br>
553 <div class="unavailable hidden">
554 <div class="form-group">
555 <div class="col-sm-2"></div>
556 <div class="col-sm-10">
557 <p>BIP141 is unavailable for this coin.</p>
558 </div>
559 </div>
560 </div>
561 <div class="available">
562 <div class="col-sm-2"></div>
563 <div class="col-sm-10">
564 <p>
565 For more info see the
566 <a href="https://github.com/bitcoin/bips/blob/master/bip-0141.mediawiki" target="_blank">BIP141 spec</a>
567 </p>
568 </div>
569 <div class="form-group">
570 <label for="bip141-path" class="col-sm-2 control-label">BIP32 Derivation Path</label>
571 <div class="col-sm-10">
572 <input id="bip141-path" type="text" class="bip141-path form-control" value="m/0">
573 </div>
574 </div>
575 <div class="form-group">
576 <label class="col-sm-2 control-label">Script Semantics</label>
577 <div class="col-sm-10">
578 <select class="form-control bip141-semantics">
579 <option value="p2wpkh">P2WPKH</option>
580 <option value="p2wpkh-p2sh" selected>P2WPKH nested in P2SH</option>
581 </select>
582 </div>
583 </div>
584 </div>
585 </form>
586 </div>
ebd8d4e8
IC
587 </div>
588 <form class="form-horizontal" role="form">
589 <div class="form-group">
fb00a22d 590 <label for="extended-priv-key" class="col-sm-2 control-label">BIP32 Extended Private Key</label>
ebd8d4e8 591 <div class="col-sm-10">
e00964cc 592 <textarea id="extended-priv-key" class="extended-priv-key form-control" readonly="readonly" data-show-qr></textarea>
ebd8d4e8
IC
593 </div>
594 </div>
595 <div class="form-group">
fb00a22d 596 <label for="extended-pub-key" class="col-sm-2 control-label">BIP32 Extended Public Key</label>
ebd8d4e8 597 <div class="col-sm-10">
e00964cc 598 <textarea id="extended-pub-key" class="extended-pub-key form-control" readonly="readonly" data-show-qr></textarea>
ebd8d4e8
IC
599 </div>
600 </div>
601 </form>
602 </div>
603 </div>
604
605 <hr>
606
607 <div class="row">
608 <div class="col-md-12">
609 <h2>Derived Addresses</h2>
fb00a22d 610 <p>Note these addreses are derived from the BIP32 Extended Key</p>
fe8f2d14
IC
611 </div>
612 <div class="col-md-12 use-bitpay-addresses-container hidden">
613 <div class="checkbox">
614 <label>
615 <input type="checkbox" class="use-bitpay-addresses">
616 <span>Use BitPay-style addresses for Bitcoin Cash (ie starting with 'C' instead of '1')</span>
617 </label>
618 </div>
619 </div>
620 <div class="col-md-12">
ebd8d4e8
IC
621 <table class="table table-striped">
622 <thead>
623 <th>
624 <div class="input-group">
fb00a22d
IC
625 <span>Path</span>&nbsp;&nbsp;
626 <button class="index-toggle">Toggle</button>
ebd8d4e8
IC
627 </div>
628 </th>
629 <th>
630 <div class="input-group">
fb00a22d
IC
631 <span>Address</span>&nbsp;&nbsp;
632 <button class="address-toggle">Toggle</button>
ebd8d4e8
IC
633 </div>
634 </th>
1b12b2f5
IC
635 <th>
636 <div class="input-group">
fb00a22d
IC
637 <span>Public Key</span>&nbsp;&nbsp;
638 <button class="public-key-toggle">Toggle</button>
1b12b2f5
IC
639 </div>
640 </th>
ebd8d4e8
IC
641 <th>
642 <div class="input-group">
fb00a22d
IC
643 <span>Private Key</span>&nbsp;&nbsp;
644 <button class="private-key-toggle">Toggle</button>
ebd8d4e8
IC
645 </div>
646 </th>
647 </thead>
d737abf6 648 <tbody class="addresses monospace">
a0a19620
IC
649 <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
650 <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
651 <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
652 <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
653 <tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>
ebd8d4e8
IC
654 </tbody>
655 </table>
656 </div>
657 </div>
9183f9f6 658 <span>Show</span>
ebd8d4e8 659 <input type="number" class="rows-to-add" value="20">
9183f9f6
IC
660 <button class="more">more rows</button>
661 <span>starting from index</span>
662 <input type="number" class="more-rows-start-index">
663 <span>(leave blank to generate from next index)</span>
ebd8d4e8
IC
664
665 <hr>
666
667 <div class="row">
668 <div class="col-md-12">
fb00a22d
IC
669 <h2>More info</h2>
670 <h3>BIP39 <span class="small">Mnemonic code for generating deterministic keys</span></h3>
671 <p>
ebd8d4e8
IC
672 Read more at the
673 <a href="https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki">official BIP39 spec</a>
674 </p>
fb00a22d
IC
675 <h3>BIP32 <span class="small">Hierarchical Deterministic Wallets</span></h3>
676 <p>
ebd8d4e8
IC
677 Read more at the
678 <a href="https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki" target="_blank">official BIP32 spec</a>
60599f7a 679 </p>
fb00a22d 680 <p>
60599f7a 681 See the demo at
ebd8d4e8
IC
682 <a href="http://bip32.org/" target="_blank">bip32.org</a>
683 </p>
fb00a22d
IC
684 <h3>BIP44 <span class="small">Multi-Account Hierarchy for Deterministic Wallets</span></h3>
685 <p>
ebd8d4e8
IC
686 Read more at the
687 <a href="https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki" target="_blank">official BIP44 spec</a>
688 </p>
fb00a22d
IC
689 <h3>BIP49 <span class="small">Derivation scheme for P2WPKH-nested-in-P2SH based accounts</span></h3>
690 <p>
861750ae
JC
691 Read more at the
692 <a href="https://github.com/bitcoin/bips/blob/master/bip-0049.mediawiki" target="_blank">official BIP49 spec</a>
693 </p>
fb00a22d 694 <h3>Private Keys</h3>
ebd8d4e8 695 <p>
fb00a22d 696 <span>
60599f7a
IC
697 Use private keys at
698 <a href="https://web.archive.org/web/20150707020924/https://brainwallet.org/" target="_blank">brainwallet.org</a>.
699 </span>
fb00a22d 700 <span>Be careful - it can be easy to make mistakes if you don't know what you're doing.</span>
ebd8d4e8 701 </p>
fb00a22d 702 <h3 id="entropy-notes">Entropy</h3>
c6624d51 703 <p>
fb00a22d 704 <span>
60599f7a
IC
705 Entropy values must be sourced from a
706 <a href="https://en.wikipedia.org/wiki/Random_number_generation" target="_blank">strong source of randomness</a>.
707 </span>
fb00a22d
IC
708 <span>This means flipping a fair coin, rolling a fair dice, noise measurements etc.</span>
709 <span>
60599f7a
IC
710 Do <strong>NOT</strong> use phrases from books, lyrics from songs, your birthday or steet address,
711 keyboard mashing, or anything you <i>think</i> is random, because chances are overwhelming it isn't
712 random enough for the needs of this tool.
713 </span>
c6624d51 714 </p>
bf9bdfd2 715 <p>
fb00a22d 716 <strong><span>Do not store entropy.</span></strong>
bf9bdfd2
IC
717 </p>
718 <p>
fb00a22d
IC
719 <span>Storing entropy (such as keeping a deck of cards in a specific shuffled order) is unreliable compared to storing a mnemonic.</span>
720 <span>Instead of storing entropy, store the mnemonic generated from the entropy.</span>
721 <span><a href="https://en.wikipedia.org/wiki/Steganography#Physical" target="_blank">Steganography</a> may be beneficial when storing the mnemonic.</span>
bf9bdfd2 722 </p>
c6624d51 723 <p>
fb00a22d 724 <span>
60599f7a
IC
725 The random mnemonic generator on this page uses a
726 <a href="https://developer.mozilla.org/en-US/docs/Web/API/RandomSource/getRandomValues" target="_blank">cryptographically secure random number generator</a>.
727 </span>
fb00a22d
IC
728 <span>The built in random generator can generally be trusted more than your own intuition about randomness.</span>
729 <span>If cryptographic randomness isn't available in your browser, this page will show a warning and the generate button will not work.</span>
730 <span>In that case you might choose to use your own source of entropy.</span>
c6624d51
IC
731 </p>
732 <p>
fb00a22d 733 <a href="https://bitcointalk.org/index.php?topic=311000.msg3345309#msg3345309" target="_blank">You are not a good source of entropy.</a>
c6624d51 734 </p>
fb00a22d 735 <h3>License</h3>
1f618a77 736 <p>
fb00a22d 737 <span>Please refer to <a href="https://github.com/iancoleman/bip39/blob/master/LICENSE" target="_blank">the software license</a> for more detail.
1f618a77
IC
738 </span>
739 </p>
fb00a22d 740 <p>The software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.</p>
ebd8d4e8
IC
741 </div>
742 </div>
45b8a745
IC
743
744 <hr>
745
73b8724a
IC
746 <div class="row">
747 <div class="col-md-12">
748 <h2>Alternative Tools</h2>
749 <p>This tool is interoperable with any BIP39 wallet.</p>
750 <p>Some similar tools to this one (ie not consumer wallets) are</p>
751 <p>
752 <a href="https://bip32jp.github.io/english/">
753 https://bip32jp.github.io/english/
754 </a>
755 </p>
756 </div>
757 </div>
758
759 <hr>
760
c5863485
IC
761 <div class="row">
762 <div class="col-md-12">
763
fb00a22d 764 <h2>Offline Usage</h2>
c5863485 765
fb00a22d 766 <p>
c5863485
IC
767 You can use this tool without having to be online.
768 </p>
fb00a22d 769 <p>
c5863485
IC
770 In your browser, select file save-as, and save this page
771 as a file.
772 </p>
fb00a22d 773 <p>
c5863485
IC
774 Double-click that file to open it in a browser
775 on any offline computer.
776 </p>
777 <p>
fb00a22d 778 <span>Alternatively, download the file from the repository</span>
60599f7a
IC
779 -
780 <a href="https://github.com/iancoleman/bip39">https://github.com/iancoleman/bip39</a>
781 </p>
c5863485
IC
782
783 </div>
784 </div>
785
786 <hr>
787
45b8a745
IC
788 <div class="row">
789 <div class="col-md-12">
790
fb00a22d 791 <h2>This project is 100% open-source code</h2>
45b8a745
IC
792
793 <p>
fb00a22d 794 <span>Get the source code from the repository</span>
60599f7a 795 -
b630f83d
IC
796 <a href="https://github.com/iancoleman/bip39" target="_blank">
797 https://github.com/iancoleman/bip39
45b8a745
IC
798 </a>
799 </p>
800
fb00a22d 801 <h3>Libraries</h3>
45b8a745
IC
802
803 <p>
804 <span>BitcoinJS - </span>
805 <a href="https://github.com/bitcoinjs/bitcoinjs-lib" target="_blank">
806 https://github.com/bitcoinjs/bitcoinjs-lib
807 </a>
808 </p>
809
810 <p>
811 <span>jsBIP39 - </span>
812 <a href="https://github.com/iancoleman/jsbip39" target="_blank">
813 https://github.com/iancoleman/jsbip39
814 </a>
815 </p>
816
817 <p>
0937f3ab
IC
818 <span>sjcl - </span>
819 <a href="https://github.com/bitwiseshiftleft/sjcl" target="_blank">
820 https://github.com/bitwiseshiftleft/sjcl
45b8a745
IC
821 </a>
822 </p>
823
824 <p>
825 <span>jQuery - </span>
826 <a href="https://jquery.com/" target="_blank">
827 https://jquery.com/
828 </a>
829 </p>
830
831 <p>
832 <span>Twitter Bootstrap - </span>
833 <a href="http://getbootstrap.com/" target="_blank">
834 http://getbootstrap.com/
835 </a>
836 </p>
837
838 </div>
839 </div>
840
ebd8d4e8
IC
841 </div>
842
e00964cc 843 <div class="qr-container hidden">
fb00a22d
IC
844 <div class="qr-hint bg-primary hidden">Click field to hide QR</div>
845 <div class="qr-hint bg-primary">Click field to show QR</div>
8a93952c 846 <div class="qr-hider hidden">
97811c29 847 <div class="qr-image"></div>
fb00a22d 848 <div class="qr-warning bg-primary">Caution: Scanner may keep history</div>
97811c29 849 </div>
e00964cc
IC
850 </div>
851
ebd8d4e8 852 <div class="feedback-container">
d26cce22 853 <div class="feedback">Loading...</div>
ebd8d4e8
IC
854 </div>
855
856 <script type="text/template" id="address-row-template">
857 <tr>
858 <td class="index"><span></span></td>
e00964cc
IC
859 <td class="address"><span data-show-qr></span></td>
860 <td class="pubkey"><span data-show-qr></span></td>
861 <td class="privkey"><span data-show-qr></span></td>
ebd8d4e8
IC
862 </tr>
863 </script>
24137d96 864 <script src="js/polyfill.es6.js"></script>
64a7d2aa 865 <script src="js/basex.js"></script>
6e0f24b1 866 <script src="js/unorm.js"></script>
cee442b1
KK
867 <script src="js/jquery.min.js"></script>
868 <script src="js/bootstrap.min.js"></script>
563e401a 869 <script src="js/levenshtein.js"></script>
e00964cc 870 <script src="js/jquery.qrcode.min.js"></script>
9f59e99b 871 <script src="js/bitcoinjs-3.3.0.js"></script>
cee442b1 872 <script src="js/bitcoinjs-extensions.js"></script>
c49e8812 873 <script src="js/segwit-parameters.js"></script>
505a3159 874 <script src="js/ethereumjs-util.js"></script>
64a7d2aa 875 <script src="js/ripple-util.js"></script>
cee442b1
KK
876 <script src="js/sjcl-bip39.js"></script>
877 <script src="js/wordlist_english.js"></script>
3a8dbe99
IC
878 <script src="js/wordlist_japanese.js"></script>
879 <script src="js/wordlist_spanish.js"></script>
880 <script src="js/wordlist_chinese_simplified.js"></script>
881 <script src="js/wordlist_chinese_traditional.js"></script>
882 <script src="js/wordlist_french.js"></script>
883 <script src="js/wordlist_italian.js"></script>
cee442b1 884 <script src="js/jsbip39.js"></script>
b6dbc2a1 885 <script src="js/biginteger.js"></script>
b299a6a7 886 <script src="js/zxcvbn.js"></script>
c6624d51 887 <script src="js/entropy.js"></script>
cee442b1 888 <script src="js/index.js"></script>
ebd8d4e8
IC
889 </body>
890</html>