-
Notifications
You must be signed in to change notification settings - Fork 158
/
bitcoin-keys.go
80 lines (58 loc) · 2.25 KB
/
bitcoin-keys.go
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
package main
import (
"fmt"
"github.com/btcsuite/btcd/btcec"
"github.com/btcsuite/btcd/chaincfg"
"github.com/btcsuite/btcutil"
"math/big"
)
var largestBitcoinSeed = new(big.Int).SetBytes([]byte{
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFE,
0xBA, 0xAE, 0xDC, 0xE6, 0xAF, 0x48, 0xA0, 0x3B, 0xBF, 0xD2, 0x5E, 0x8C, 0xD0, 0x36, 0x41, 0x40,
})
type key struct {
private string
compressed string
uncompressed string
}
func generateBitcoinKeys(pageNumber string, keysPerPage int) (keys []key) {
basePage := new(big.Int).Sub(makeBigInt(pageNumber), one)
// convert the "int" to "string" because i dont know how to create a bigInt from an "int"
stringInt := fmt.Sprintf("%d", keysPerPage)
firstSeed := new(big.Int).Add(new(big.Int).Mul(basePage, makeBigInt(stringInt)), one)
var padded [32]byte
bitcoinKeys := make([]key, 0, keysPerPage)
for i := 0; i < keysPerPage; i++ {
// Check to make sure we're not out of range
if firstSeed.Cmp(largestBitcoinSeed) > 0 {
break
}
// Copy firstSeed value's bytes to padded slice
copy(padded[32-len(firstSeed.Bytes()):], firstSeed.Bytes())
// Get private and public keys
privKey, public := btcec.PrivKeyFromBytes(btcec.S256(), padded[:])
// Get compressed and uncompressed addresses for public key
caddr, _ := btcutil.NewAddressPubKey(public.SerializeCompressed(), &chaincfg.MainNetParams)
uaddr, _ := btcutil.NewAddressPubKey(public.SerializeUncompressed(), &chaincfg.MainNetParams)
// Encode addresses
wif, _ := btcutil.NewWIF(privKey, &chaincfg.MainNetParams, false)
bitcoinKeys = append(bitcoinKeys, key{
private: wif.String(),
compressed: caddr.EncodeAddress(),
uncompressed: uaddr.EncodeAddress(),
})
firstSeed.Add(firstSeed, one)
}
return bitcoinKeys
}
func findBtcWifPage(wifString string, keysPerPage int) string {
wif, err := btcutil.DecodeWIF(wifString)
if err != nil {
return "Error: could not decoding WIF"
}
// convert the "int" to "string" because i dont know how to create a bigInt from an "int"
stringInt := fmt.Sprintf("%d", keysPerPage)
page, _ := new(big.Int).DivMod(new(big.Int).SetBytes(wif.PrivKey.D.Bytes()), makeBigInt(stringInt), makeBigInt(stringInt))
page.Add(page, one)
return page.String()
}