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