Advertisement
skip420

seed

Mar 12th, 2021 (edited)
1,583
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 20.54 KB | None | 0 0
  1.  
  2. #
  3. #
  4. #
  5. import hashlib, ecdsa
  6. from ecdsa.curves import SECP256k1
  7. from ecdsa.ellipticcurve import Point
  8. from ecdsa.util import string_to_number, number_to_string
  9. from ecdsa.ecdsa import curve_secp256k1, generator_secp256k1
  10. #
  11. #
  12. #
  13. #
  14. #
  15. #
  16.  
  17.  
  18.  
  19.  
  20.  
  21. ##--------------------------------------------------------------------------
  22.  
  23. numberofreceivingaddresses=5;
  24. numberofchangeaddresses=5;
  25.  
  26. ##--------------------------------------------------------------------------
  27. def sha256(x):
  28.     return hashlib.sha256(x).digest()
  29.  
  30. def Hash(x):
  31.     if type(x) is unicode: x=x.encode('utf-8')
  32.     return sha256(sha256(x))
  33.  
  34. def pw_decode(s, password):
  35.     if password is not None:
  36.         secret = Hash(password)
  37.         try:
  38.             d = DecodeAES(secret, s).decode("utf8")
  39.         except Exception:
  40.             raise Exception('Invalid password')
  41.         return d
  42.     else:
  43.         return s
  44.  
  45. def get_address(mpk,  for_change, n):
  46.         pubkey =  get_pubkey(mpk,for_change, n)
  47.         address = public_key_to_bc_address( pubkey.decode('hex') )
  48.    
  49.         return address
  50.  
  51.  
  52. def get_pubkey(mpk, for_change, n):
  53.         curve = SECP256k1
  54.         z = get_sequence(mpk,for_change,n);
  55.         master_public_key = ecdsa.VerifyingKey.from_string( mpk, curve = SECP256k1 )
  56.         pubkey_point = master_public_key.pubkey.point + z*curve.generator
  57.         public_key2 = ecdsa.VerifyingKey.from_public_point( pubkey_point, curve = SECP256k1 )
  58.         return '04' + public_key2.to_string().encode('hex')
  59.  
  60. def get_sequence(mpk, for_change, n):
  61.         return string_to_number( Hash( "%d:%d:"%(n,for_change) + mpk ) )
  62.  
  63. def get_private_key_from_stretched_exponent(mpk,for_change, n, secexp):
  64.         order = generator_secp256k1.order()
  65.         secexp = ( secexp + get_sequence(mpk,for_change, n) ) % order
  66.         pk = number_to_string( secexp, generator_secp256k1.order() )
  67.         compressed = False
  68.         return SecretToASecret( pk, compressed )
  69.        
  70. def get_private_key(mpk,seed, sequence):
  71.         for_change, n = sequence
  72.         secexp = stretch_key(seed)
  73.         pk = get_private_key_from_stretched_exponent(mpk,for_change, n, secexp)
  74.         return pk;
  75.  
  76. def stretch_key(seed):
  77.         oldseed = seed
  78.         for i in range(100000):
  79.             seed = hashlib.sha256(seed + oldseed).digest()
  80.         return string_to_number( seed )
  81.  
  82. def public_key_to_bc_address(public_key):
  83.     h160 = hash_160(public_key)
  84.     return hash_160_to_bc_address(h160)
  85.  
  86. def SecretToASecret(secret, compressed=False, addrtype=0):
  87.     vchIn = chr((addrtype+128)&255) + secret
  88.     if compressed: vchIn += '\01'
  89.     return EncodeBase58Check(vchIn)
  90.  
  91. def EncodeBase58Check(vchIn):
  92.     hash = Hash(vchIn)
  93.     return b58encode(vchIn + hash[0:4])
  94.  
  95. def b58encode(v):
  96.     """ encode v, which is a string of bytes, to base58."""
  97.  
  98.     long_value = 0L
  99.     for (i, c) in enumerate(v[::-1]):
  100.         long_value += (256**i) * ord(c)
  101.     result = ''
  102.     while long_value >= __b58base:
  103.         div, mod = divmod(long_value, __b58base)
  104.         result = __b58chars[mod] + result
  105.         long_value = div
  106.     result = __b58chars[long_value] + result
  107.  
  108.     # Bitcoin does a little leading-zero-compression:
  109.     # leading 0-bytes in the input become leading-1s
  110.     nPad = 0
  111.     for c in v:
  112.         if c == '\0': nPad += 1
  113.         else: break
  114.  
  115.     return (__b58chars[0]*nPad) + result
  116.  
  117. def hash_160(public_key):
  118.     try:
  119.         md = hashlib.new('ripemd160')
  120.         md.update(sha256(public_key))
  121.         return md.digest()
  122.     except Exception:
  123.         import ripemd
  124.         md = ripemd.new(sha256(public_key))
  125.         return md.digest()
  126.    
  127. def hash_160_to_bc_address(h160, addrtype = 0):
  128.     vh160 = chr(addrtype) + h160
  129.     h = Hash(vh160)
  130.     addr = vh160 + h[0:4]
  131.     return b58encode(addr)
  132.  
  133. __b58chars = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'
  134. __b58base = len(__b58chars)
  135.  
  136. ##-------------------------------------------------------------------------------
  137.  
  138. words = [ "like", "just", "love", "know", "never", "want", "time", "out", "there", "make", "look", "eye", "down", "only", "think", "heart", "back", "then", "into", "about", "more", "away", "still", "them", "take", "thing", "even", "through", "long", "always", "world", "too", "friend", "tell", "try", "hand", "thought", "over", "here", "other", "need", "smile", "again", "much", "cry", "been", "night", "ever", "little", "said", "end", "some", "those", "around", "mind", "people", "girl", "leave", "dream", "left", "turn", "myself", "give", "nothing", "really", "off", "before", "something", "find", "walk", "wish", "good", "once", "place", "ask", "stop", "keep", "watch", "seem", "everything", "wait", "got", "yet", "made", "remember", "start", "alone", "run", "hope", "maybe", "believe", "body", "hate", "after", "close", "talk", "stand", "own", "each", "hurt", "help", "home", "god", "soul", "new", "many", "two", "inside", "should", "true", "first", "fear", "mean", "better", "play", "another", "gone", "change", "use", "wonder", "someone", "hair", "cold", "open", "best", "any", "behind", "happen", "water", "dark", "laugh", "stay", "forever", "name", "work", "show", "sky", "break", "came", "deep", "door", "put", "black", "together", "upon", "happy", "such", "great", "white", "matter", "fill", "past", "please", "burn", "cause", "enough", "touch", "moment", "soon", "voice", "scream", "anything", "stare", "sound", "red", "everyone", "hide", "kiss", "truth", "death", "beautiful", "mine", "blood", "broken", "very", "pass", "next", "forget", "tree", "wrong", "air", "mother", "understand", "lip", "hit", "wall", "memory", "sleep", "free", "high", "realize", "school", "might", "skin", "sweet", "perfect", "blue", "kill", "breath", "dance", "against", "fly", "between", "grow", "strong", "under", "listen", "bring", "sometimes", "speak", "pull", "person", "become", "family", "begin", "ground", "real", "small", "father", "sure", "feet", "rest", "young", "finally", "land", "across", "today", "different", "guy", "line", "fire", "reason", "reach", "second", "slowly", "write", "eat", "smell", "mouth", "step", "learn", "three", "floor", "promise", "breathe", "darkness", "push", "earth", "guess", "save", "song", "above", "along", "both", "color", "house", "almost", "sorry", "anymore", "brother", "okay", "dear", "game", "fade", "already", "apart", "warm", "beauty", "heard", "notice", "question", "shine", "began", "piece", "whole", "shadow", "secret", "street", "within", "finger", "point", "morning", "whisper", "child", "moon", "green", "story", "glass", "kid", "silence", "since", "soft", "yourself", "empty", "shall", "angel", "answer", "baby", "bright", "dad", "path", "worry", "hour", "drop", "follow", "power", "war", "half", "flow", "heaven", "act", "chance", "fact", "least", "tired", "children", "near", "quite", "afraid", "rise", "sea", "taste", "window", "cover", "nice", "trust", "lot", "sad", "cool", "force", "peace", "return", "blind", "easy", "ready", "roll", "rose", "drive", "held", "music", "beneath", "hang", "mom", "paint", "emotion", "quiet", "clear", "cloud", "few", "pretty", "bird", "outside", "paper", "picture", "front", "rock", "simple", "anyone", "meant", "reality", "road", "sense", "waste", "bit", "leaf", "thank", "happiness", "meet", "men", "smoke", "truly", "decide", "self", "age", "book", "form", "alive", "carry", "escape", "damn", "instead", "able", "ice", "minute", "throw", "catch", "leg", "ring", "course", "goodbye", "lead", "poem", "sick", "corner", "desire", "known", "problem", "remind", "shoulder", "suppose", "toward", "wave", "drink", "jump", "woman", "pretend", "sister", "week", "human", "joy", "crack", "grey", "pray", "surprise", "dry", "knee", "less", "search", "bleed", "caught", "clean", "embrace", "future", "king", "son", "sorrow", "chest", "hug", "remain", "sat", "worth", "blow", "daddy", "final", "parent", "tight", "also", "create", "lonely", "safe", "cross", "dress", "evil", "silent", "bone", "fate", "perhaps", "anger", "class", "scar", "snow", "tiny", "tonight", "continue", "control", "dog", "edge", "mirror", "month", "suddenly", "comfort", "given", "loud", "quickly", "gaze", "plan", "rush", "stone", "town", "battle", "ignore", "spirit", "stood", "stupid", "yours", "brown", "build", "dust", "hey", "kept", "pay", "phone", "twist", "although", "ball", "beyond", "hidden", "nose", "taken", "fail", "float", "pure", "somehow", "wash", "wrap", "angry", "cheek", "creature", "forgotten", "heat", "rip", "single", "space", "special", "weak", "whatever", "yell", "anyway", "blame", "job", "choose", "country", "curse", "drift", "echo", "figure", "grew", "laughter", "neck", "suffer", "worse", "yeah", "disappear", "foot", "forward", "knife", "mess", "somewhere", "stomach", "storm", "beg", "idea", "lift", "offer", "breeze", "field", "five", "often", "simply", "stuck", "win", "allow", "confuse", "enjoy", "except", "flower", "seek", "strength", "calm", "grin", "gun", "heavy", "hill", "large", "ocean", "shoe", "sigh", "straight", "summer", "tongue", "accept", "crazy", "everyday", "exist", "grass", "mistake", "sent", "shut", "surround", "table", "ache", "brain", "destroy", "heal", "nature", "shout", "sign", "stain", "choice", "doubt", "glance", "glow", "mountain", "queen", "stranger", "throat", "tomorrow", "city", "either", "fish", "flame", "rather", "shape", "spin", "spread", "ash", "distance", "finish", "image", "imagine", "important", "nobody", "shatter", "warmth", "became", "feed", "flesh", "funny", "lust", "shirt", "trouble", "yellow", "attention", "bare", "bite", "money", "protect", "amaze", "appear", "born", "choke", "completely", "daughter", "fresh", "friendship", "gentle", "probably", "six", "deserve", "expect", "grab", "middle", "nightmare", "river", "thousand", "weight", "worst", "wound", "barely", "bottle", "cream", "regret", "relationship", "stick", "test", "crush", "endless", "fault", "itself", "rule", "spill", "art", "circle", "join", "kick", "mask", "master", "passion", "quick", "raise", "smooth", "unless", "wander", "actually", "broke", "chair", "deal", "favorite", "gift", "note", "number", "sweat", "box", "chill", "clothes", "lady", "mark", "park", "poor", "sadness", "tie", "animal", "belong", "brush", "consume", "dawn", "forest", "innocent", "pen", "pride", "stream", "thick", "clay", "complete", "count", "draw", "faith", "press", "silver", "struggle", "surface", "taught", "teach", "wet", "bless", "chase", "climb", "enter", "letter", "melt", "metal", "movie", "stretch", "swing", "vision", "wife", "beside", "crash", "forgot", "guide", "haunt", "joke", "knock", "plant", "pour", "prove", "reveal", "steal", "stuff", "trip", "wood", "wrist", "bother", "bottom", "crawl", "crowd", "fix", "forgive", "frown", "grace", "loose", "lucky", "party", "release", "surely", "survive", "teacher", "gently", "grip", "speed", "suicide", "travel", "treat", "vein", "written", "cage", "chain", "conversation", "date", "enemy", "however", "interest", "million", "page", "pink", "proud", "sway", "themselves", "winter", "church", "cruel", "cup", "demon", "experience", "freedom", "pair", "pop", "purpose", "respect", "shoot", "softly", "state", "strange", "bar", "birth", "curl", "dirt", "excuse", "lord", "lovely", "monster", "order", "pack", "pants", "pool", "scene", "seven", "shame", "slide", "ugly", "among", "blade", "blonde", "closet", "creek", "deny", "drug", "eternity", "gain", "grade", "handle", "key", "linger", "pale", "prepare", "swallow", "swim", "tremble", "wheel", "won", "cast", "cigarette", "claim", "college", "direction", "dirty", "gather", "ghost", "hundred", "loss", "lung", "orange", "present", "swear", "swirl", "twice", "wild", "bitter", "blanket", "doctor", "everywhere", "flash", "grown", "knowledge", "numb", "pressure", "radio", "repeat", "ruin", "spend", "unknown", "buy", "clock", "devil", "early", "false", "fantasy", "pound", "precious", "refuse", "sheet", "teeth", "welcome", "add", "ahead", "block", "bury", "caress", "content", "depth", "despite", "distant", "marry", "purple", "threw", "whenever", "bomb", "dull", "easily", "grasp", "hospital", "innocence", "normal", "receive", "reply", "rhyme", "shade", "someday", "sword", "toe", "visit", "asleep", "bought", "center", "consider", "flat", "hero", "history", "ink", "insane", "muscle", "mystery", "pocket", "reflection", "shove", "silently", "smart", "soldier", "spot", "stress", "train", "type", "view", "whether", "bus", "energy", "explain", "holy", "hunger", "inch", "magic", "mix", "noise", "nowhere", "prayer", "presence", "shock", "snap", "spider", "study", "thunder", "trail", "admit", "agree", "bag", "bang", "bound", "butterfly", "cute", "exactly", "explode", "familiar", "fold", "further", "pierce", "reflect", "scent", "selfish", "sharp", "sink", "spring", "stumble", "universe", "weep", "women", "wonderful", "action", "ancient", "attempt", "avoid", "birthday", "branch", "chocolate", "core", "depress", "drunk", "especially", "focus", "fruit", "honest", "match", "palm", "perfectly", "pillow", "pity", "poison", "roar", "shift", "slightly", "thump", "truck", "tune", "twenty", "unable", "wipe", "wrote", "coat", "constant", "dinner", "drove", "egg", "eternal", "flight", "flood", "frame", "freak", "gasp", "glad", "hollow", "motion", "peer", "plastic", "root", "screen", "season", "sting", "strike", "team", "unlike", "victim", "volume", "warn", "weird", "attack", "await", "awake", "built", "charm", "crave", "despair", "fought", "grant", "grief", "horse", "limit", "message", "ripple", "sanity", "scatter", "serve", "split", "string", "trick", "annoy", "blur", "boat", "brave", "clearly", "cling", "connect", "fist", "forth", "imagination", "iron", "jock", "judge", "lesson", "milk", "misery", "nail", "naked", "ourselves", "poet", "possible", "princess", "sail", "size", "snake", "society", "stroke", "torture", "toss", "trace", "wise", "bloom", "bullet", "cell", "check", "cost", "darling", "during", "footstep", "fragile", "hallway", "hardly", "horizon", "invisible", "journey", "midnight", "mud", "nod", "pause", "relax", "shiver", "sudden", "value", "youth", "abuse", "admire", "blink", "breast", "bruise", "constantly", "couple", "creep", "curve", "difference", "dumb", "emptiness", "gotta", "honor", "plain", "planet", "recall", "rub", "ship", "slam", "soar", "somebody", "tightly", "weather", "adore", "approach", "bond", "bread", "burst", "candle", "coffee", "cousin", "crime", "desert", "flutter", "frozen", "grand", "heel", "hello", "language", "level", "movement", "pleasure", "powerful", "random", "rhythm", "settle", "silly", "slap", "sort", "spoken", "steel", "threaten", "tumble", "upset", "aside", "awkward", "bee", "blank", "board", "button", "card", "carefully", "complain", "crap", "deeply", "discover", "drag", "dread", "effort", "entire", "fairy", "giant", "gotten", "greet", "illusion", "jeans", "leap", "liquid", "march", "mend", "nervous", "nine", "replace", "rope", "spine", "stole", "terror", "accident", "apple", "balance", "boom", "childhood", "collect", "demand", "depression", "eventually", "faint", "glare", "goal", "group", "honey", "kitchen", "laid", "limb", "machine", "mere", "mold", "murder", "nerve", "painful", "poetry", "prince", "rabbit", "shelter", "shore", "shower", "soothe", "stair", "steady", "sunlight", "tangle", "tease", "treasure", "uncle", "begun", "bliss", "canvas", "cheer", "claw", "clutch", "commit", "crimson", "crystal", "delight", "doll", "existence", "express", "fog", "football", "gay", "goose", "guard", "hatred", "illuminate", "mass", "math", "mourn", "rich", "rough", "skip", "stir", "student", "style", "support", "thorn", "tough", "yard", "yearn", "yesterday", "advice", "appreciate", "autumn", "bank", "beam", "bowl", "capture", "carve", "collapse", "confusion", "creation", "dove", "feather", "girlfriend", "glory", "government", "harsh", "hop", "inner", "loser", "moonlight", "neighbor", "neither", "peach", "pig", "praise", "screw", "shield", "shimmer", "sneak", "stab", "subject", "throughout", "thrown", "tower", "twirl", "wow", "army", "arrive", "bathroom", "bump", "cease", "cookie", "couch", "courage", "dim", "guilt", "howl", "hum", "husband", "insult", "led", "lunch", "mock", "mostly", "natural", "nearly", "needle", "nerd", "peaceful", "perfection", "pile", "price", "remove", "roam", "sanctuary", "serious", "shiny", "shook", "sob", "stolen", "tap", "vain", "void", "warrior", "wrinkle", "affection", "apologize", "blossom", "bounce", "bridge", "cheap", "crumble", "decision", "descend", "desperately", "dig", "dot", "flip", "frighten", "heartbeat", "huge", "lazy", "lick", "odd", "opinion", "process", "puzzle", "quietly", "retreat", "score", "sentence", "separate", "situation", "skill", "soak", "square", "stray", "taint", "task", "tide", "underneath", "veil", "whistle", "anywhere", "bedroom", "bid", "bloody", "burden", "careful", "compare", "concern", "curtain", "decay", "defeat", "describe", "double", "dreamer", "driver", "dwell", "evening", "flare", "flicker", "grandma", "guitar", "harm", "horrible", "hungry", "indeed", "lace", "melody", "monkey", "nation", "object", "obviously", "rainbow", "salt", "scratch", "shown", "shy", "stage", "stun", "third", "tickle", "useless", "weakness", "worship", "worthless", "afternoon", "beard", "boyfriend", "bubble", "busy", "certain", "chin", "concrete", "desk", "diamond", "doom", "drawn", "due", "felicity", "freeze", "frost", "garden", "glide", "harmony", "hopefully", "hunt", "jealous", "lightning", "mama", "mercy", "peel", "physical", "position", "pulse", "punch", "quit", "rant", "respond", "salty", "sane", "satisfy", "savior", "sheep", "slept", "social", "sport", "tuck", "utter", "valley", "wolf", "aim", "alas", "alter", "arrow", "awaken", "beaten", "belief", "brand", "ceiling", "cheese", "clue", "confidence", "connection", "daily", "disguise", "eager", "erase", "essence", "everytime", "expression", "fan", "flag", "flirt", "foul", "fur", "giggle", "glorious", "ignorance", "law", "lifeless", "measure", "mighty", "muse", "north", "opposite", "paradise", "patience", "patient", "pencil", "petal", "plate", "ponder", "possibly", "practice", "slice", "spell", "stock", "strife", "strip", "suffocate", "suit", "tender", "tool", "trade", "velvet", "verse", "waist", "witch", "aunt", "bench", "bold", "cap", "certainly", "click", "companion", "creator", "dart", "delicate", "determine", "dish", "dragon", "drama", "drum", "dude", "everybody", "feast", "forehead", "former", "fright", "fully", "gas", "hook", "hurl", "invite", "juice", "manage", "moral", "possess", "raw", "rebel", "royal", "scale", "scary", "several", "slight", "stubborn", "swell", "talent", "tea", "terrible", "thread", "torment", "trickle", "usually", "vast", "violence", "weave", "acid", "agony", "ashamed", "awe", "belly", "blend", "blush", "character", "cheat", "common", "company", "coward", "creak", "danger", "deadly", "defense", "define", "depend", "desperate", "destination", "dew", "duck", "dusty", "embarrass", "engine", "example", "explore", "foe", "freely", "frustrate", "generation", "glove", "guilty", "health", "hurry", "idiot", "impossible", "inhale", "jaw", "kingdom", "mention", "mist", "moan", "mumble", "mutter", "observe", "ode", "pathetic", "pattern", "pie", "prefer", "puff", "rape", "rare", "revenge", "rude", "scrape", "spiral", "squeeze", "strain", "sunset", "suspend", "sympathy", "thigh", "throne", "total", "unseen", "weapon", "weary" ]
  139.  
  140. def mn_decode( wlist ):
  141.     n=1626;
  142.     out = ''
  143.     for i in range(len(wlist)/3):
  144.         word1, word2, word3 = wlist[3*i:3*i+3]
  145.         w1 =  words.index(word1)
  146.         w2 = (words.index(word2))%n
  147.         w3 = (words.index(word3))%n
  148.         x = w1 +n*((w2-w1)%n) +n*n*((w3-w2)%n)
  149.         out += '%08x'%x
  150.     return out
  151.  
  152. ##--------------------------------------------------------------------------------
  153.  
  154.  
  155.  
  156. clue="1pP35yQkzWe9sPwxrfMS1AQEMoyQc91pa"
  157.  
  158.  
  159. origseed=["constant", "forest", "adore", "false", "green", "weave", "stop", "guy", "fur", "freeze", "giggle", "clock"];
  160.  
  161.  
  162.  
  163.  
  164. for x in range(0, 12):
  165.    myseed=origseed[:];
  166.    for y in range(0,1626):
  167.     variedword=words[y];
  168.  
  169.     myseed2 = ""
  170.     myseed[x]=variedword;
  171.         for i in myseed:
  172.             myseed2 += str(i) + "  ";
  173.             myseed2 = myseed2[:-1]
  174.         print "Attempting seed: "+myseed2; 
  175.         seed=myseed2;
  176.     print " ";
  177.     plainseed=seed;
  178.     print "We're on seed word "+str(x+1)+" iteration "+str(y);
  179.     print " ";
  180.     seedlist=str.split(seed);
  181.     password = None;
  182.     seed=mn_decode(seedlist);
  183.     oldseed=seed;
  184.     newseed=stretch_key(seed);
  185.     curve = SECP256k1
  186.     master_private_key = ecdsa.SigningKey.from_secret_exponent( newseed, curve = SECP256k1 );
  187.     master_public_key = master_private_key.get_verifying_key().to_string().encode('hex');
  188.     mpk=master_public_key.decode('hex');
  189.     for ra in range(0,numberofreceivingaddresses):
  190.         foundseed=0;
  191.         addy=get_address(mpk,0,ra);
  192.         if addy==clue:
  193.             print "WOWWWWWWW!!! FOUND THE SEED!!!";
  194.             foundseed=1;
  195.             print plainseed;
  196.         if foundseed==1:
  197.             quit()
  198.                  
  199.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement