Browse Source

Merge pull request #238 from dcousens/bs58check

package: use bs58check
hk-custom-address
Wei Lu 11 years ago
parent
commit
7aaf6e0681
  1. 1
      package.json
  2. 2
      src/address.js
  3. 32
      src/base58check.js
  4. 2
      src/eckey.js
  5. 2
      src/hdnode.js
  6. 1
      src/index.js
  7. 34
      test/base58check.js
  8. 2
      test/bitcoin.core.js
  9. 209
      test/fixtures/base58check.json

1
package.json

@ -74,6 +74,7 @@
"dependencies": { "dependencies": {
"bigi": "1.1.0", "bigi": "1.1.0",
"bs58": "1.1.0", "bs58": "1.1.0",
"bs58check": "1.0.0",
"crypto-js": "3.1.2-3", "crypto-js": "3.1.2-3",
"crypto-browserify": "2.1.8", "crypto-browserify": "2.1.8",
"ecurve": "0.10.0", "ecurve": "0.10.0",

2
src/address.js

@ -1,5 +1,5 @@
var assert = require('assert') var assert = require('assert')
var base58check = require('./base58check') var base58check = require('bs58check')
var networks = require('./networks') var networks = require('./networks')
var scripts = require('./scripts') var scripts = require('./scripts')

32
src/base58check.js

@ -1,32 +0,0 @@
// https://en.bitcoin.it/wiki/Base58Check_encoding
var assert = require('assert')
var base58 = require('bs58')
var crypto = require('./crypto')
// Encode a buffer as a base58-check-encoded string
function encode(payload) {
var checksum = crypto.hash256(payload).slice(0, 4)
return base58.encode(Buffer.concat([
payload,
checksum
]))
}
// Decode a base58-check-encoded string to a buffer
function decode(string) {
var buffer = base58.decode(string)
var payload = buffer.slice(0, -4)
var checksum = buffer.slice(-4)
var newChecksum = crypto.hash256(payload).slice(0, 4)
assert.deepEqual(newChecksum, checksum, 'Invalid checksum')
return payload
}
module.exports = {
encode: encode,
decode: decode
}

2
src/eckey.js

@ -1,5 +1,5 @@
var assert = require('assert') var assert = require('assert')
var base58check = require('./base58check') var base58check = require('bs58check')
var ecdsa = require('./ecdsa') var ecdsa = require('./ecdsa')
var networks = require('./networks') var networks = require('./networks')
var secureRandom = require('secure-random') var secureRandom = require('secure-random')

2
src/hdnode.js

@ -1,5 +1,5 @@
var assert = require('assert') var assert = require('assert')
var base58check = require('./base58check') var base58check = require('bs58check')
var crypto = require('./crypto') var crypto = require('./crypto')
var networks = require('./networks') var networks = require('./networks')

1
src/index.js

@ -1,6 +1,5 @@
module.exports = { module.exports = {
Address: require('./address'), Address: require('./address'),
base58check: require('./base58check'),
bufferutils: require('./bufferutils'), bufferutils: require('./bufferutils'),
convert: require('./convert'), convert: require('./convert'),
crypto: require('./crypto'), crypto: require('./crypto'),

34
test/base58check.js

@ -1,34 +0,0 @@
var assert = require('assert')
var base58check = require('../src/base58check')
var fixtures = require('./fixtures/base58check.json')
describe('base58check', function() {
describe('decode', function() {
fixtures.valid.forEach(function(f) {
it('can decode ' + f.string, function() {
var actual = base58check.decode(f.string).toString('hex')
assert.equal(actual, f.payload)
})
})
fixtures.invalid.forEach(function(f) {
it('throws on ' + f, function() {
assert.throws(function() {
base58check.decode(f)
}, /Invalid checksum/)
})
})
})
describe('encode', function() {
fixtures.valid.forEach(function(f) {
it('can encode ' + f.string, function() {
var actual = base58check.encode(new Buffer(f.payload, 'hex'))
assert.strictEqual(actual, f.string)
})
})
})
})

2
test/bitcoin.core.js

@ -1,6 +1,6 @@
var assert = require('assert') var assert = require('assert')
var base58 = require('bs58') var base58 = require('bs58')
var base58check = require('../src/base58check') var base58check = require('bs58check')
var networks = require('../src/networks') var networks = require('../src/networks')
var Address = require('../src/address') var Address = require('../src/address')

209
test/fixtures/base58check.json

@ -1,209 +0,0 @@
{
"valid": [
{
"string": "1AGNa15ZQXAZUgFiqJ2i7Z2DPU2J6hW62i",
"payload": "0065a16059864a2fdbc7c99a4723a8395bc6f188eb"
},
{
"string": "3CMNFxN1oHBc4R1EpboAL5yzHGgE611Xou",
"payload": "0574f209f6ea907e2ea48f74fae05782ae8a665257"
},
{
"string": "mo9ncXisMeAoXwqcV5EWuyncbmCcQN4rVs",
"payload": "6f53c0307d6851aa0ce7825ba883c6bd9ad242b486"
},
{
"string": "2N2JD6wb56AfK4tfmM6PwdVmoYk2dCKf4Br",
"payload": "c46349a418fc4578d10a372b54b45c280cc8c4382f"
},
{
"string": "5Kd3NBUAdUnhyzenEwVLy9pBKxSwXvE9FMPyR4UKZvpe6E3AgLr",
"payload": "80eddbdc1168f1daeadbd3e44c1e3f8f5a284c2029f78ad26af98583a499de5b19"
},
{
"string": "Kz6UJmQACJmLtaQj5A3JAge4kVTNQ8gbvXuwbmCj7bsaabudb3RD",
"payload": "8055c9bccb9ed68446d1b75273bbce89d7fe013a8acd1625514420fb2aca1a21c401"
},
{
"string": "9213qJab2HNEpMpYNBa7wHGFKKbkDn24jpANDs2huN3yi4J11ko",
"payload": "ef36cb93b9ab1bdabf7fb9f2c04f1b9cc879933530ae7842398eef5a63a56800c2"
},
{
"string": "cTpB4YiyKiBcPxnefsDpbnDxFDffjqJob8wGCEDXxgQ7zQoMXJdH",
"payload": "efb9f4892c9e8282028fea1d2667c4dc5213564d41fc5783896a0d843fc15089f301"
},
{
"string": "1Ax4gZtb7gAit2TivwejZHYtNNLT18PUXJ",
"payload": "006d23156cbbdcc82a5a47eee4c2c7c583c18b6bf4"
},
{
"string": "3QjYXhTkvuj8qPaXHTTWb5wjXhdsLAAWVy",
"payload": "05fcc5460dd6e2487c7d75b1963625da0e8f4c5975"
},
{
"string": "n3ZddxzLvAY9o7184TB4c6FJasAybsw4HZ",
"payload": "6ff1d470f9b02370fdec2e6b708b08ac431bf7a5f7"
},
{
"string": "2NBFNJTktNa7GZusGbDbGKRZTxdK9VVez3n",
"payload": "c4c579342c2c4c9220205e2cdc285617040c924a0a"
},
{
"string": "5K494XZwps2bGyeL71pWid4noiSNA2cfCibrvRWqcHSptoFn7rc",
"payload": "80a326b95ebae30164217d7a7f57d72ab2b54e3be64928a19da0210b9568d4015e"
},
{
"string": "L1RrrnXkcKut5DEMwtDthjwRcTTwED36thyL1DebVrKuwvohjMNi",
"payload": "807d998b45c219a1e38e99e7cbd312ef67f77a455a9b50c730c27f02c6f730dfb401"
},
{
"string": "93DVKyFYwSN6wEo3E2fCrFPUp17FtrtNi2Lf7n4G3garFb16CRj",
"payload": "efd6bca256b5abc5602ec2e1c121a08b0da2556587430bcf7e1898af2224885203"
},
{
"string": "cTDVKtMGVYWTHCb1AFjmVbEbWjvKpKqKgMaR3QJxToMSQAhmCeTN",
"payload": "efa81ca4e8f90181ec4b61b6a7eb998af17b2cb04de8a03b504b9e34c4c61db7d901"
},
{
"string": "1C5bSj1iEGUgSTbziymG7Cn18ENQuT36vv",
"payload": "007987ccaa53d02c8873487ef919677cd3db7a6912"
},
{
"string": "3AnNxabYGoTxYiTEZwFEnerUoeFXK2Zoks",
"payload": "0563bcc565f9e68ee0189dd5cc67f1b0e5f02f45cb"
},
{
"string": "n3LnJXCqbPjghuVs8ph9CYsAe4Sh4j97wk",
"payload": "6fef66444b5b17f14e8fae6e7e19b045a78c54fd79"
},
{
"string": "2NB72XtkjpnATMggui83aEtPawyyKvnbX2o",
"payload": "c4c3e55fceceaa4391ed2a9677f4a4d34eacd021a0"
},
{
"string": "5KaBW9vNtWNhc3ZEDyNCiXLPdVPHCikRxSBWwV9NrpLLa4LsXi9",
"payload": "80e75d936d56377f432f404aabb406601f892fd49da90eb6ac558a733c93b47252"
},
{
"string": "L1axzbSyynNYA8mCAhzxkipKkfHtAXYF4YQnhSKcLV8YXA874fgT",
"payload": "808248bd0375f2f75d7e274ae544fb920f51784480866b102384190b1addfbaa5c01"
},
{
"string": "927CnUkUbasYtDwYwVn2j8GdTuACNnKkjZ1rpZd2yBB1CLcnXpo",
"payload": "ef44c4f6a096eac5238291a94cc24c01e3b19b8d8cef72874a079e00a242237a52"
},
{
"string": "cUcfCMRjiQf85YMzzQEk9d1s5A4K7xL5SmBCLrezqXFuTVefyhY7",
"payload": "efd1de707020a9059d6d3abaf85e17967c6555151143db13dbb06db78df0f15c6901"
},
{
"string": "1Gqk4Tv79P91Cc1STQtU3s1W6277M2CVWu",
"payload": "00adc1cc2081a27206fae25792f28bbc55b831549d"
},
{
"string": "33vt8ViH5jsr115AGkW6cEmEz9MpvJSwDk",
"payload": "05188f91a931947eddd7432d6e614387e32b244709"
},
{
"string": "mhaMcBxNh5cqXm4aTQ6EcVbKtfL6LGyK2H",
"payload": "6f1694f5bc1a7295b600f40018a618a6ea48eeb498"
},
{
"string": "2MxgPqX1iThW3oZVk9KoFcE5M4JpiETssVN",
"payload": "c43b9b3fd7a50d4f08d1a5b0f62f644fa7115ae2f3"
},
{
"string": "5HtH6GdcwCJA4ggWEL1B3jzBBUB8HPiBi9SBc5h9i4Wk4PSeApR",
"payload": "80091035445ef105fa1bb125eccfb1882f3fe69592265956ade751fd095033d8d0"
},
{
"string": "L2xSYmMeVo3Zek3ZTsv9xUrXVAmrWxJ8Ua4cw8pkfbQhcEFhkXT8",
"payload": "80ab2b4bcdfc91d34dee0ae2a8c6b6668dadaeb3a88b9859743156f462325187af01"
},
{
"string": "92xFEve1Z9N8Z641KQQS7ByCSb8kGjsDzw6fAmjHN1LZGKQXyMq",
"payload": "efb4204389cef18bbe2b353623cbf93e8678fbc92a475b664ae98ed594e6cf0856"
},
{
"string": "cVM65tdYu1YK37tNoAyGoJTR13VBYFva1vg9FLuPAsJijGvG6NEA",
"payload": "efe7b230133f1b5489843260236b06edca25f66adb1be455fbd38d4010d48faeef01"
},
{
"string": "1JwMWBVLtiqtscbaRHai4pqHokhFCbtoB4",
"payload": "00c4c1b72491ede1eedaca00618407ee0b772cad0d"
},
{
"string": "3QCzvfL4ZRvmJFiWWBVwxfdaNBT8EtxB5y",
"payload": "05f6fe69bcb548a829cce4c57bf6fff8af3a5981f9"
},
{
"string": "mizXiucXRCsEriQCHUkCqef9ph9qtPbZZ6",
"payload": "6f261f83568a098a8638844bd7aeca039d5f2352c0"
},
{
"string": "2NEWDzHWwY5ZZp8CQWbB7ouNMLqCia6YRda",
"payload": "c4e930e1834a4d234702773951d627cce82fbb5d2e"
},
{
"string": "5KQmDryMNDcisTzRp3zEq9e4awRmJrEVU1j5vFRTKpRNYPqYrMg",
"payload": "80d1fab7ab7385ad26872237f1eb9789aa25cc986bacc695e07ac571d6cdac8bc0"
},
{
"string": "L39Fy7AC2Hhj95gh3Yb2AU5YHh1mQSAHgpNixvm27poizcJyLtUi",
"payload": "80b0bbede33ef254e8376aceb1510253fc3550efd0fcf84dcd0c9998b288f166b301"
},
{
"string": "91cTVUcgydqyZLgaANpf1fvL55FH53QMm4BsnCADVNYuWuqdVys",
"payload": "ef037f4192c630f399d9271e26c575269b1d15be553ea1a7217f0cb8513cef41cb"
},
{
"string": "cQspfSzsgLeiJGB2u8vrAiWpCU4MxUT6JseWo2SjXy4Qbzn2fwDw",
"payload": "ef6251e205e8ad508bab5596bee086ef16cd4b239e0cc0c5d7c4e6035441e7d5de01"
},
{
"string": "19dcawoKcZdQz365WpXWMhX6QCUpR9SY4r",
"payload": "005eadaf9bb7121f0f192561a5a62f5e5f54210292"
},
{
"string": "37Sp6Rv3y4kVd1nQ1JV5pfqXccHNyZm1x3",
"payload": "053f210e7277c899c3a155cc1c90f4106cbddeec6e"
},
{
"string": "myoqcgYiehufrsnnkqdqbp69dddVDMopJu",
"payload": "6fc8a3c2a09a298592c3e180f02487cd91ba3400b5"
},
{
"string": "2N7FuwuUuoTBrDFdrAZ9KxBmtqMLxce9i1C",
"payload": "c499b31df7c9068d1481b596578ddbb4d3bd90baeb"
},
{
"string": "5KL6zEaMtPRXZKo1bbMq7JDjjo1bJuQcsgL33je3oY8uSJCR5b4",
"payload": "80c7666842503db6dc6ea061f092cfb9c388448629a6fe868d068c42a488b478ae"
},
{
"string": "KwV9KAfwbwt51veZWNscRTeZs9CKpojyu1MsPnaKTF5kz69H1UN2",
"payload": "8007f0803fc5399e773555ab1e8939907e9badacc17ca129e67a2f5f2ff84351dd01"
},
{
"string": "93N87D6uxSBzwXvpokpzg8FFmfQPmvX4xHoWQe3pLdYpbiwT5YV",
"payload": "efea577acfb5d1d14d3b7b195c321566f12f87d2b77ea3a53f68df7ebf8604a801"
},
{
"string": "cMxXusSihaX58wpJ3tNuuUcZEQGt6DKJ1wEpxys88FFaQCYjku9h",
"payload": "ef0b3b34f0958d8a268193a9814da92c3e8b58b4a4378a542863e34ac289cd830c01"
},
{
"string": "13p1ijLwsnrcuyqcTvJXkq2ASdXqcnEBLE",
"payload": "001ed467017f043e91ed4c44b4e8dd674db211c4e6"
},
{
"string": "3ALJH9Y951VCGcVZYAdpA3KchoP9McEj1G",
"payload": "055ece0cadddc415b1980f001785947120acdb36fc"
}
],
"invalid": [
"Z9inZq4e2HGQRZQezDjFMmqgUE8NwMRok",
"3HK7MezAm6qEZQUMPRf8jX7wDv6zig6Ky8",
"3AW8j12DUk8mgA7kkfZ1BrrzCVFuH1LsXS"
]
}
Loading…
Cancel
Save