-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbip39.js
More file actions
341 lines (321 loc) · 23.6 KB
/
bip39.js
File metadata and controls
341 lines (321 loc) · 23.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
// BIP39 English Word List
const BIP39_WORDS = [
"abandon", "ability", "able", "about", "above", "absent", "absorb", "abstract", "absurd", "abuse",
"access", "accident", "account", "accuse", "achieve", "acid", "acoustic", "acquire", "across", "act",
"action", "actor", "actress", "actual", "adapt", "add", "addict", "address", "adjust", "admit",
"adult", "advance", "advice", "aerobic", "affair", "afford", "afraid", "again", "age", "agent",
"agree", "ahead", "aim", "air", "airport", "aisle", "alarm", "album", "alcohol", "alert",
"alien", "all", "alley", "allow", "almost", "alone", "alpha", "already", "also", "alter",
"always", "amateur", "amazing", "among", "amount", "amused", "analyst", "anchor", "ancient", "anger",
"angle", "angry", "animal", "ankle", "announce", "annual", "another", "answer", "antenna", "antique",
"anxiety", "any", "apart", "apology", "appear", "apple", "approve", "april", "arch", "arctic",
"area", "arena", "argue", "arm", "armed", "armor", "army", "around", "arrange", "arrest",
"arrive", "arrow", "art", "artefact", "artist", "artwork", "ask", "aspect", "assault", "asset",
"assist", "assume", "asthma", "athlete", "atom", "attack", "attend", "attitude", "attract", "auction",
"audit", "august", "aunt", "author", "auto", "autumn", "average", "avocado", "avoid", "awake",
"aware", "away", "awesome", "awful", "awkward", "axis", "baby", "bachelor", "bacon", "badge",
"bag", "balance", "balcony", "ball", "bamboo", "banana", "banner", "bar", "barely", "bargain",
"barrel", "base", "basic", "basket", "battle", "beach", "bean", "beauty", "because", "become",
"beef", "before", "begin", "behave", "behind", "believe", "below", "belt", "bench", "benefit",
"best", "betray", "better", "between", "beyond", "bicycle", "bid", "bike", "bind", "biology",
"bird", "birth", "bitter", "black", "blade", "blame", "blanket", "blast", "bleak", "bless",
"blind", "blood", "blossom", "blouse", "blue", "blur", "blush", "board", "boat", "body",
"boil", "bomb", "bone", "bonus", "book", "boost", "border", "boring", "borrow", "boss",
"bottom", "bounce", "box", "boy", "bracket", "brain", "brand", "brass", "brave", "bread",
"breeze", "brick", "bridge", "brief", "bright", "bring", "brisk", "broccoli", "broken", "bronze",
"broom", "brother", "brown", "brush", "bubble", "buddy", "budget", "buffalo", "build", "bulb",
"bulk", "bullet", "bundle", "bunker", "burden", "burger", "burst", "bus", "business", "busy",
"butter", "buyer", "buzz", "cabbage", "cabin", "cable", "cactus", "cage", "cake", "call",
"calm", "camera", "camp", "can", "canal", "cancel", "candy", "cannon", "canoe", "canvas",
"canyon", "capable", "capital", "captain", "car", "carbon", "card", "cargo", "carpet", "carry",
"cart", "case", "cash", "casino", "castle", "casual", "cat", "catalog", "catch", "category",
"cattle", "caught", "cause", "caution", "cave", "ceiling", "celery", "cement", "census", "century",
"cereal", "certain", "chair", "chalk", "champion", "change", "chaos", "chapter", "charge", "chase",
"chat", "cheap", "check", "cheese", "chef", "cherry", "chest", "chicken", "chief", "child",
"chimney", "choice", "choose", "chronic", "chuckle", "chunk", "churn", "cigar", "cinnamon", "citizen",
"city", "civil", "claim", "clap", "clarify", "claw", "clay", "clean", "clerk", "clever",
"click", "client", "cliff", "climb", "clinic", "clip", "clock", "clog", "close", "cloth",
"cloud", "clown", "club", "clump", "cluster", "clutch", "coach", "coast", "coconut", "code",
"coffee", "coil", "coin", "collect", "color", "column", "combine", "come", "comfort", "comic",
"common", "company", "concert", "conduct", "confirm", "congress", "connect", "consider", "control", "convince",
"cook", "cool", "copper", "copy", "coral", "core", "corn", "correct", "cost", "cotton",
"couch", "country", "couple", "course", "cousin", "cover", "coyote", "crack", "cradle", "craft",
"cram", "crane", "crash", "crater", "crawl", "crazy", "cream", "credit", "creek", "crew",
"cricket", "crime", "crisp", "critic", "crop", "cross", "crouch", "crowd", "crucial", "cruel",
"cruise", "crumble", "crunch", "crush", "cry", "crystal", "cube", "culture", "cup", "cupboard",
"curious", "current", "curtain", "curve", "cushion", "custom", "cute", "cycle", "dad", "damage",
"damp", "dance", "danger", "daring", "dash", "daughter", "dawn", "day", "deal", "debate",
"debris", "decade", "december", "decide", "decline", "decorate", "decrease", "deer", "defense", "define",
"defy", "degree", "delay", "deliver", "demand", "demise", "denial", "dentist", "deny", "depart",
"depend", "deposit", "depth", "deputy", "derive", "describe", "desert", "design", "desk", "despair",
"destroy", "detail", "detect", "develop", "device", "devote", "diagram", "dial", "diamond", "diary",
"dice", "diesel", "diet", "differ", "digital", "dignity", "dilemma", "dinner", "dinosaur", "direct",
"dirt", "disagree", "discover", "disease", "dish", "dismiss", "disorder", "display", "distance", "divert",
"divide", "divorce", "dizzy", "doctor", "document", "dog", "doll", "dolphin", "domain", "donate",
"donkey", "donor", "door", "dose", "double", "dove", "draft", "dragon", "drama", "drastic",
"draw", "dream", "dress", "drift", "drill", "drink", "drip", "drive", "drop", "drum",
"dry", "duck", "dumb", "dune", "during", "dust", "dutch", "duty", "dwarf", "dynamic",
"eager", "eagle", "early", "earn", "earth", "easily", "east", "easy", "echo", "ecology",
"economy", "edge", "edit", "educate", "effort", "egg", "eight", "either", "elbow", "elder",
"electric", "elegant", "element", "elephant", "elevator", "elite", "else", "embark", "embody", "embrace",
"emerge", "emotion", "employ", "empower", "empty", "enable", "enact", "end", "endless", "endorse",
"enemy", "energy", "enforce", "engage", "engine", "enhance", "enjoy", "enlist", "enough", "enrich",
"enroll", "ensure", "enter", "entire", "entry", "envelope", "episode", "equal", "equip", "era",
"erase", "erode", "erosion", "error", "erupt", "escape", "essay", "essence", "estate", "eternal",
"ethics", "evidence", "evil", "evoke", "evolve", "exact", "example", "excess", "exchange", "excite",
"exclude", "excuse", "execute", "exercise", "exhaust", "exhibit", "exile", "exist", "exit", "exotic",
"expand", "expect", "expire", "explain", "expose", "express", "extend", "extra", "eye", "eyebrow",
"fabric", "face", "faculty", "fade", "faint", "faith", "fall", "false", "fame", "family",
"famous", "fan", "fancy", "fantasy", "farm", "fashion", "fat", "fatal", "father", "fatigue",
"fault", "favorite", "feature", "february", "federal", "fee", "feed", "feel", "female", "fence",
"festival", "fetch", "fever", "few", "fiber", "fiction", "field", "figure", "file", "film",
"filter", "final", "find", "fine", "finger", "finish", "fire", "firm", "first", "fiscal",
"fish", "fit", "fitness", "fix", "flag", "flame", "flash", "flat", "flavor", "flee",
"flight", "flip", "float", "flock", "floor", "flower", "fluid", "flush", "fly", "foam",
"focus", "fog", "foil", "fold", "follow", "food", "foot", "force", "forest", "forget",
"fork", "fortune", "forum", "forward", "fossil", "foster", "found", "fox", "fragile", "frame",
"frequent", "fresh", "friend", "fringe", "frog", "front", "frost", "frown", "frozen", "fruit",
"fuel", "fun", "funny", "furnace", "fury", "future", "gadget", "gain", "galaxy", "gallery",
"game", "gap", "garage", "garbage", "garden", "garlic", "garment", "gas", "gasp", "gate",
"gather", "gauge", "gaze", "general", "genius", "genre", "gentle", "genuine", "gesture", "ghost",
"giant", "gift", "giggle", "ginger", "giraffe", "girl", "give", "glad", "glance", "glare",
"glass", "glide", "glimpse", "globe", "gloom", "glory", "glove", "glow", "glue", "goat",
"goddess", "gold", "good", "goose", "gorilla", "gospel", "gossip", "govern", "gown", "grab",
"grace", "grain", "grant", "grape", "grass", "gravity", "great", "green", "grid", "grief",
"grit", "grocery", "group", "grow", "grunt", "guard", "guess", "guide", "guilt", "guitar",
"gun", "gym", "habit", "hair", "half", "hammer", "hamster", "hand", "happy",
"harbor", "hard", "harsh", "harvest", "hat", "have", "hawk", "hazard", "head", "health",
"heart", "heavy", "hedgehog", "height", "hello", "helmet", "help", "hen", "hero", "hidden",
"high", "hill", "hint", "hip", "hire", "history", "hobby", "hockey", "hold", "hole",
"holiday", "hollow", "home", "honey", "hood", "hope", "horn", "horror", "horse", "hospital",
"host", "hotel", "hour", "hover", "hub", "huge", "human", "humble", "humor", "hundred",
"hungry", "hunt", "hurdle", "hurry", "hurt", "husband", "hybrid", "ice", "icon", "idea",
"identify", "idle", "ignore", "ill", "illegal", "illness", "image", "imitate", "immense", "immune",
"impact", "impose", "improve", "impulse", "inch", "include", "income", "increase", "index", "indicate",
"indoor", "industry", "infant", "inflict", "inform", "inhale", "inherit", "initial", "inject", "injury",
"inmate", "inner", "innocent", "inquiry", "insane", "insect", "inside", "inspire", "install", "intact",
"interest", "into", "invest", "invite", "involve", "iron", "island", "isolate", "issue", "item",
"ivory", "jacket", "jaguar", "jar", "jazz", "jealous", "jeans", "jelly", "jewel", "job",
"join", "joke", "journey", "joy", "judge", "juice", "jump", "jungle", "junior", "junk",
"just", "kangaroo", "keen", "keep", "ketchup", "key", "kick", "kid", "kidney", "kind",
"kingdom", "kiss", "kit", "kitchen", "kite", "kitten", "kiwi", "knee", "knife", "knock",
"know", "lab", "label", "labor", "ladder", "lady", "lake", "lamp", "language", "laptop",
"large", "later", "latin", "laugh", "laundry", "lava", "law", "lawn", "lawsuit", "layer",
"lazy", "lecture", "left", "leg", "legal", "legend", "leisure", "lemon", "lend", "length",
"lens", "leopard", "lesson", "letter", "level", "liar", "liberty", "library", "license", "life",
"lift", "light", "like", "limb", "limit", "link", "lion", "liquid", "list", "little",
"live", "lizard", "load", "loan", "lobster", "local", "lock", "logic", "lonely", "long",
"loop", "lottery", "loud", "lounge", "love", "loyal", "lucky", "luggage", "lumber", "lunar",
"lunch", "luxury", "lyrics", "machine", "mad", "magic", "magnet", "maid", "mail", "main",
"major", "make", "mammal", "man", "manage", "mandate", "mango", "mansion", "manual", "maple",
"marble", "march", "margin", "marine", "market", "marriage", "mask", "mass", "master", "match",
"material", "math", "matrix", "matter", "maximum", "maze", "meadow", "mean", "measure", "meat",
"mechanic", "medal", "media", "melody", "melt", "member", "memory", "mention", "menu", "mercy",
"merge", "merit", "merry", "mesh", "message", "metal", "method", "middle", "midnight", "milk",
"million", "mimic", "mind", "minimum", "minor", "minute", "miracle", "mirror", "misery", "miss",
"mistake", "mix", "mixed", "mixture", "mobile", "model", "modify", "mom", "moment", "monitor",
"monkey", "monster", "month", "moon", "moral", "more", "morning", "mosquito", "mother", "motion",
"motor", "mountain", "mouse", "move", "movie", "much", "muffin", "mule", "multiply", "muscle",
"museum", "mushroom", "music", "must", "mutual", "myself", "mystery", "myth", "naive", "name",
"napkin", "narrow", "nasty", "nation", "nature", "near", "neck", "need", "negative", "neglect",
"neither", "nephew", "nerve", "nest", "net", "network", "neutral", "never", "news", "next",
"nice", "night", "noble", "noise", "nominee", "noodle", "normal", "north", "nose", "notable",
"note", "nothing", "notice", "novel", "now", "nuclear", "number", "nurse", "nut", "oak",
"obey", "object", "oblige", "obscure", "observe", "obtain", "obvious", "occur", "ocean", "october",
"odor", "off", "offer", "office", "often", "oil", "okay", "old", "olive", "olympic",
"omit", "once", "one", "onion", "online", "only", "open", "opera", "opinion", "oppose",
"option", "orange", "orbit", "orchard", "order", "ordinary", "organ", "orient", "original", "orphan",
"ostrich", "other", "outdoor", "outer", "output", "outside", "oval", "oven", "over", "own",
"owner", "oxygen", "oyster", "ozone", "pact", "paddle", "page", "pair", "palace", "palm",
"panda", "panel", "panic", "panther", "paper", "parade", "parent", "park", "parrot", "party",
"pass", "patch", "path", "patient", "patrol", "pattern", "pause", "pave", "payment", "peace",
"peanut", "pear", "peasant", "pelican", "pen", "penalty", "pencil", "people", "pepper", "perfect",
"permit", "person", "pet", "phone", "photo", "phrase", "physical", "piano", "picnic", "picture",
"piece", "pig", "pigeon", "pill", "pilot", "pink", "pioneer", "pipe", "pistol", "pitch",
"pizza", "place", "planet", "plastic", "plate", "play", "please", "pledge", "pluck", "plug",
"plunge", "poem", "poet", "point", "polar", "pole", "police", "pond", "pony", "pool",
"popular", "portion", "position", "possible", "post", "potato", "pottery", "poverty", "powder", "power",
"practice", "praise", "predict", "prefer", "prepare", "present", "pretty", "prevent", "price", "pride",
"primary", "print", "priority", "prison", "private", "prize", "problem", "process", "produce", "profit",
"program", "project", "promote", "proof", "property", "prosper", "protect", "proud", "provide", "public",
"pudding", "pull", "pulp", "pulse", "pumpkin", "punch", "pupil", "puppy", "purchase", "purity",
"purpose", "purse", "push", "put", "puzzle", "pyramid", "quality", "quantum", "quarter", "question",
"quick", "quit", "quiz", "quote", "rabbit", "raccoon", "race", "rack", "radar", "radio",
"rail", "rain", "raise", "rally", "ramp", "ranch", "random", "range", "rapid", "rare",
"rate", "rather", "raven", "raw", "razor", "ready", "real", "reason", "rebel", "rebuild",
"recall", "receive", "recipe", "record", "recycle", "reduce", "reflect", "reform", "refuse", "region",
"regret", "regular", "reject", "relax", "release", "relief", "rely", "remain", "remember", "remind",
"remove", "render", "renew", "rent", "reopen", "repair", "repeat", "replace", "report", "require",
"rescue", "resemble", "resist", "resource", "response", "result", "retire", "retreat", "return", "reunion",
"reveal", "review", "reward", "rhythm", "rib", "ribbon", "rice", "rich", "ride", "ridge",
"rifle", "right", "rigid", "ring", "riot", "ripple", "risk", "ritual", "rival", "river",
"road", "roast", "robot", "robust", "rocket", "romance", "roof", "rookie", "room", "rose",
"rotate", "rough", "round", "route", "royal", "rubber", "rude", "rug", "rule", "run",
"runway", "rural", "sad", "saddle", "sadness", "safe", "sail", "salad", "salmon", "salon",
"salt", "salute", "same", "sample", "sand", "satisfy", "satoshi", "sauce", "sausage", "save",
"say", "scale", "scan", "scare", "scatter", "scene", "scheme", "school", "science", "scissors",
"scorpion", "scout", "scrap", "screen", "script", "scrub", "sea", "search", "season", "seat",
"second", "secret", "section", "security", "seed", "seek", "segment", "select", "sell", "seminar",
"senior", "sense", "sentence", "series", "service", "session", "settle", "setup", "seven", "shadow",
"shaft", "shallow", "share", "shed", "shell", "sheriff", "shield", "shift", "shine", "ship",
"shiver", "shock", "shoe", "shoot", "shop", "short", "shoulder", "shove", "shrimp", "shrug",
"shuffle", "shy", "sibling", "sick", "side", "siege", "sight", "sign", "silent", "silk",
"silly", "silver", "similar", "simple", "since", "sing", "siren", "sister", "situate", "six",
"size", "skate", "sketch", "ski", "skill", "skin", "skirt", "skull", "slab", "slam",
"sleep", "slender", "slice", "slide", "slight", "slim", "slogan", "slot", "slow", "slush",
"small", "smart", "smile", "smoke", "smooth", "snack", "snake", "snap", "sniff", "snow",
"soap", "soccer", "social", "sock", "soda", "soft", "solar", "soldier", "solid", "solution",
"solve", "someone", "song", "soon", "sorry", "sort", "soul", "sound", "soup", "source",
"south", "space", "spare", "spatial", "spawn", "speak", "special", "speed", "spell", "spend",
"sphere", "spice", "spider", "spike", "spin", "spirit", "split", "spoil", "sponsor", "spoon",
"sport", "spot", "spray", "spread", "spring", "spy", "square", "squeeze", "squirrel", "stable",
"stadium", "staff", "stage", "stairs", "stamp", "stand", "start", "state", "stay", "steak",
"steel", "stem", "step", "stereo", "stick", "still", "sting", "stock", "stomach", "stone",
"stool", "story", "stove", "strategy", "street", "strike", "strong", "struggle", "student", "stuff",
"stumble", "style", "subject", "submit", "subway", "success", "such", "sudden", "suffer", "sugar",
"suggest", "suit", "summer", "sun", "sunny", "sunset", "super", "supply", "supreme", "sure",
"surface", "surge", "surprise", "surround", "survey", "suspect", "sustain", "swallow", "swamp", "swap",
"swarm", "swear", "sweet", "swift", "swim", "swing", "switch", "sword", "symbol", "symptom",
"syrup", "system", "table", "tackle", "tag", "tail", "talent", "talk", "tank", "tape",
"target", "task", "taste", "tattoo", "taxi", "teach", "team", "tell", "ten", "tenant",
"tennis", "tent", "term", "test", "text", "thank", "that", "theme", "then", "theory",
"there", "they", "thing", "this", "thought", "three", "thrive", "throw", "thumb", "thunder",
"ticket", "tide", "tiger", "tilt", "timber", "time", "tiny", "tip", "tired", "tissue",
"title", "toast", "tobacco", "today", "toddler", "toe", "together", "toilet", "token", "tomato",
"tomorrow", "tone", "tongue", "tonight", "tool", "tooth", "top", "topic", "topple", "torch",
"tornado", "tortoise", "toss", "total", "tourist", "toward", "tower", "town", "toy", "track",
"trade", "traffic", "tragic", "train", "transfer", "trap", "trash", "travel", "tray", "treat",
"tree", "trend", "trial", "tribe", "trick", "trigger", "trim", "trip", "trophy", "trouble",
"truck", "true", "truly", "trumpet", "trust", "truth", "try", "tube", "tuition", "tumble",
"tuna", "tunnel", "turkey", "turn", "turtle", "twelve", "twenty", "twice", "twin", "twist",
"two", "type", "typical", "ugly", "umbrella", "unable", "unaware", "uncle", "uncover", "under",
"undo", "unfair", "unfold", "unhappy", "uniform", "unique", "unit", "universe", "unknown", "unlock",
"until", "unusual", "unveil", "update", "upgrade", "uphold", "upon", "upper", "upset", "urban",
"urge", "usage", "use", "used", "useful", "useless", "usual", "utility", "vacant", "vacuum",
"vague", "valid", "valley", "valve", "van", "vanish", "vapor", "various", "vast", "vault",
"vehicle", "velvet", "vendor", "venture", "venue", "verb", "verify", "version", "very", "vessel",
"veteran", "viable", "vibrant", "vicious", "victory", "video", "view", "village", "vintage", "violin",
"virtual", "virus", "visa", "visit", "visual", "vital", "vivid", "vocal", "voice", "void",
"volcano", "volume", "vote", "voyage", "wage", "wagon", "wait", "walk", "wall", "walnut",
"want", "warfare", "warm", "warrior", "wash", "wasp", "waste", "water", "wave", "way",
"wealth", "weapon", "wear", "weasel", "weather", "web", "wedding", "weekend", "weird", "welcome",
"west", "wet", "whale", "what", "wheat", "wheel", "when", "where", "whip", "whisper",
"wide", "width", "wife", "wild", "will", "win", "window", "wine", "wing", "wink",
"winner", "winter", "wire", "wisdom", "wise", "wish", "witness", "wolf", "woman", "wonder",
"wood", "wool", "word", "work", "world", "worry", "worth", "wrap", "wreck", "wrestle",
"wrist", "write", "wrong", "yard", "year", "yellow", "you", "young", "youth", "zebra",
"zero", "zone", "zoo"
];
// SHA256 Implementation
function sha256(message) {
// Constants
const K = [
0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,
0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,
0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,
0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,
0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,
0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,
0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,
0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2
];
// Initial hash values
let h0 = 0x6a09e667;
let h1 = 0xbb67ae85;
let h2 = 0x3c6ef372;
let h3 = 0xa54ff53a;
let h4 = 0x510e527f;
let h5 = 0x9b05688c;
let h6 = 0x1f83d9ab;
let h7 = 0x5be0cd19;
// Helper functions
function rightRotate(x, n) {
return (x >>> n) | (x << (32 - n));
}
function sigma0(x) {
return rightRotate(x, 2) ^ rightRotate(x, 13) ^ rightRotate(x, 22);
}
function sigma1(x) {
return rightRotate(x, 6) ^ rightRotate(x, 11) ^ rightRotate(x, 25);
}
function gamma0(x) {
return rightRotate(x, 7) ^ rightRotate(x, 18) ^ (x >>> 3);
}
function gamma1(x) {
return rightRotate(x, 17) ^ rightRotate(x, 19) ^ (x >>> 10);
}
function ch(x, y, z) {
return (x & y) ^ (~x & z);
}
function maj(x, y, z) {
return (x & y) ^ (x & z) ^ (y & z);
}
// Convert message to binary string
let binary = '';
for (let i = 0; i < message.length; i++) {
binary += message[i].charCodeAt(0).toString(2).padStart(8, '0');
}
// Add padding
const l = binary.length;
const k = (448 - (l + 1)) % 512;
binary += '1' + '0'.repeat(k) + l.toString(2).padStart(64, '0');
// Process message in 512-bit blocks
for (let i = 0; i < binary.length; i += 512) {
const block = binary.substr(i, 512);
const words = new Array(64);
// Break block into 16 32-bit words
for (let j = 0; j < 16; j++) {
words[j] = parseInt(block.substr(j * 32, 32), 2);
}
// Extend the 16 words into 64 words
for (let j = 16; j < 64; j++) {
words[j] = (gamma1(words[j - 2]) + words[j - 7] + gamma0(words[j - 15]) + words[j - 16]) >>> 0;
}
// Initialize working variables
let a = h0;
let b = h1;
let c = h2;
let d = h3;
let e = h4;
let f = h5;
let g = h6;
let h = h7;
// Main loop
for (let j = 0; j < 64; j++) {
const t1 = (h + sigma1(e) + ch(e, f, g) + K[j] + words[j]) >>> 0;
const t2 = (sigma0(a) + maj(a, b, c)) >>> 0;
h = g;
g = f;
f = e;
e = (d + t1) >>> 0;
d = c;
c = b;
b = a;
a = (t1 + t2) >>> 0;
}
// Add this block's hash to result
h0 = (h0 + a) >>> 0;
h1 = (h1 + b) >>> 0;
h2 = (h2 + c) >>> 0;
h3 = (h3 + d) >>> 0;
h4 = (h4 + e) >>> 0;
h5 = (h5 + f) >>> 0;
h6 = (h6 + g) >>> 0;
h7 = (h7 + h) >>> 0;
}
// Produce final hash value
const hash = [
h0.toString(16).padStart(8, '0'),
h1.toString(16).padStart(8, '0'),
h2.toString(16).padStart(8, '0'),
h3.toString(16).padStart(8, '0'),
h4.toString(16).padStart(8, '0'),
h5.toString(16).padStart(8, '0'),
h6.toString(16).padStart(8, '0'),
h7.toString(16).padStart(8, '0')
].join('');
return hash;
}
// Export functions
window.BIP39_WORDS = BIP39_WORDS;
window.sha256 = sha256;