@opcat-labs/opcat 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mocharc.yaml +3 -0
- package/index.d.ts +1541 -0
- package/index.js +74 -0
- package/lib/address.js +478 -0
- package/lib/block/block.js +277 -0
- package/lib/block/blockheader.js +295 -0
- package/lib/block/index.js +4 -0
- package/lib/block/merkleblock.js +323 -0
- package/lib/bn.js +3423 -0
- package/lib/crypto/bn.js +278 -0
- package/lib/crypto/ecdsa.js +339 -0
- package/lib/crypto/hash.browser.js +171 -0
- package/lib/crypto/hash.js +2 -0
- package/lib/crypto/hash.node.js +171 -0
- package/lib/crypto/point.js +221 -0
- package/lib/crypto/random.browser.js +28 -0
- package/lib/crypto/random.js +2 -0
- package/lib/crypto/random.node.js +11 -0
- package/lib/crypto/signature.js +325 -0
- package/lib/encoding/base58.js +111 -0
- package/lib/encoding/base58check.js +121 -0
- package/lib/encoding/bufferreader.js +212 -0
- package/lib/encoding/bufferwriter.js +140 -0
- package/lib/encoding/decode-asm.js +24 -0
- package/lib/encoding/decode-hex.js +32 -0
- package/lib/encoding/decode-script-chunks.js +43 -0
- package/lib/encoding/encode-hex.js +284 -0
- package/lib/encoding/is-hex.js +7 -0
- package/lib/encoding/varint.js +75 -0
- package/lib/errors/index.js +54 -0
- package/lib/errors/spec.js +314 -0
- package/lib/hash-cache.js +50 -0
- package/lib/hdprivatekey.js +678 -0
- package/lib/hdpublickey.js +525 -0
- package/lib/message/message.js +191 -0
- package/lib/mnemonic/mnemonic.js +303 -0
- package/lib/mnemonic/pbkdf2.browser.js +68 -0
- package/lib/mnemonic/pbkdf2.js +2 -0
- package/lib/mnemonic/pbkdf2.node.js +68 -0
- package/lib/mnemonic/words/chinese.js +2054 -0
- package/lib/mnemonic/words/english.js +2054 -0
- package/lib/mnemonic/words/french.js +2054 -0
- package/lib/mnemonic/words/index.js +8 -0
- package/lib/mnemonic/words/italian.js +2054 -0
- package/lib/mnemonic/words/japanese.js +2054 -0
- package/lib/mnemonic/words/spanish.js +2054 -0
- package/lib/networks.js +379 -0
- package/lib/opcode.js +255 -0
- package/lib/privatekey.js +374 -0
- package/lib/publickey.js +386 -0
- package/lib/script/index.js +5 -0
- package/lib/script/interpreter.js +1834 -0
- package/lib/script/script.js +1074 -0
- package/lib/script/stack.js +109 -0
- package/lib/script/write-i32-le.js +17 -0
- package/lib/script/write-push-data.js +35 -0
- package/lib/script/write-u16-le.js +12 -0
- package/lib/script/write-u32-le.js +16 -0
- package/lib/script/write-u64-le.js +24 -0
- package/lib/script/write-u8-le.js +8 -0
- package/lib/script/write-varint.js +46 -0
- package/lib/transaction/index.js +7 -0
- package/lib/transaction/input/index.js +5 -0
- package/lib/transaction/input/input.js +354 -0
- package/lib/transaction/input/multisig.js +242 -0
- package/lib/transaction/input/publickey.js +100 -0
- package/lib/transaction/input/publickeyhash.js +118 -0
- package/lib/transaction/output.js +231 -0
- package/lib/transaction/sighash.js +167 -0
- package/lib/transaction/signature.js +97 -0
- package/lib/transaction/transaction.js +1639 -0
- package/lib/transaction/unspentoutput.js +113 -0
- package/lib/util/_.js +47 -0
- package/lib/util/js.js +90 -0
- package/lib/util/preconditions.js +33 -0
- package/package.json +26 -0
- package/test/address.js +509 -0
- package/test/block/block.js +251 -0
- package/test/block/blockheader.js +275 -0
- package/test/block/merklebloack.js +211 -0
- package/test/crypto/bn.js +177 -0
- package/test/crypto/ecdsa.js +391 -0
- package/test/crypto/hash.browser.js +135 -0
- package/test/crypto/hash.js +136 -0
- package/test/crypto/point.js +224 -0
- package/test/crypto/random.js +32 -0
- package/test/crypto/signature.js +409 -0
- package/test/data/bip69.json +215 -0
- package/test/data/bitcoind/base58_keys_invalid.json +52 -0
- package/test/data/bitcoind/base58_keys_valid.json +335 -0
- package/test/data/bitcoind/blocks.json +22 -0
- package/test/data/bitcoind/script_tests.json +3822 -0
- package/test/data/bitcoind/sig_canonical.json +7 -0
- package/test/data/bitcoind/sig_noncanonical.json +36 -0
- package/test/data/bitcoind/tx_invalid.json +445 -0
- package/test/data/bitcoind/tx_valid.json +44 -0
- package/test/data/blk86756-testnet.dat +0 -0
- package/test/data/blk86756-testnet.js +14 -0
- package/test/data/blk86756-testnet.json +684 -0
- package/test/data/block.hex +1 -0
- package/test/data/ecdsa.json +230 -0
- package/test/data/merkleblocks.js +488 -0
- package/test/data/messages.json +22 -0
- package/test/data/sighash.json +12 -0
- package/test/data/tx_creation.json +95 -0
- package/test/encoding/base58.js +131 -0
- package/test/encoding/base58check.js +136 -0
- package/test/encoding/bufferreader.js +337 -0
- package/test/encoding/bufferwriter.js +172 -0
- package/test/encoding/varint.js +104 -0
- package/test/hashCache.js +67 -0
- package/test/hdkeys.js +445 -0
- package/test/hdprivatekey.js +332 -0
- package/test/hdpublickey.js +304 -0
- package/test/index.js +16 -0
- package/test/message/message.js +204 -0
- package/test/mnemonic/data/fixtures.json +300 -0
- package/test/mnemonic/mnemonic.js +259 -0
- package/test/mnemonic/mocha.opts +1 -0
- package/test/mnemonic/pbkdf2.test.js +59 -0
- package/test/networks.js +159 -0
- package/test/opcode.js +161 -0
- package/test/privatekey.js +439 -0
- package/test/publickey.js +554 -0
- package/test/script/interpreter.js +734 -0
- package/test/script/script.js +1437 -0
- package/test/transaction/deserialize.js +34 -0
- package/test/transaction/input/input.js +90 -0
- package/test/transaction/input/multisig.js +90 -0
- package/test/transaction/input/publickey.js +68 -0
- package/test/transaction/input/publickeyhash.js +51 -0
- package/test/transaction/output.js +185 -0
- package/test/transaction/sighash.js +65 -0
- package/test/transaction/signature.js +114 -0
- package/test/transaction/transaction.js +1109 -0
- package/test/transaction/unspentoutput.js +110 -0
- package/test/util/js.js +76 -0
- package/test/util/preconditions.js +79 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
require('chai').should();
|
|
4
|
+
var expect = require('chai').expect;
|
|
5
|
+
|
|
6
|
+
var opcat = require('../..');
|
|
7
|
+
var Transaction = opcat.Transaction;
|
|
8
|
+
var TransactionSignature = opcat.Transaction.Signature;
|
|
9
|
+
var Script = opcat.Script;
|
|
10
|
+
var PrivateKey = opcat.PrivateKey;
|
|
11
|
+
var errors = opcat.errors;
|
|
12
|
+
|
|
13
|
+
describe('TransactionSignature', function () {
|
|
14
|
+
var fromAddress = 'mszYqVnqKoQx4jcTdJXxwKAissE3Jbrrc1';
|
|
15
|
+
var privateKey = 'cSBnVM4xvxarwGQuAfQFwqDg9k5tErHUHzgWsEfD4zdwUasvqRVY';
|
|
16
|
+
var simpleUtxoWith100000Satoshis = {
|
|
17
|
+
address: fromAddress,
|
|
18
|
+
txId: 'a477af6b2667c29670467e4e0728b685ee07b240235771862318e29ddbe58458',
|
|
19
|
+
outputIndex: 0,
|
|
20
|
+
script: Script.buildPublicKeyHashOut(fromAddress).toString(),
|
|
21
|
+
satoshis: 100000,
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
var getSignatureFromTransaction = function () {
|
|
25
|
+
var transaction = new Transaction();
|
|
26
|
+
transaction.from(simpleUtxoWith100000Satoshis);
|
|
27
|
+
return transaction.getSignatures(privateKey)[0];
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
it('can be created without the `new` keyword', function () {
|
|
31
|
+
var signature = getSignatureFromTransaction();
|
|
32
|
+
var serialized = signature.toObject();
|
|
33
|
+
var nonew = TransactionSignature(serialized);
|
|
34
|
+
expect(nonew.toObject()).to.deep.equal(serialized);
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it('can be retrieved from Transaction#getSignatures', function () {
|
|
38
|
+
var signature = getSignatureFromTransaction();
|
|
39
|
+
expect(signature instanceof TransactionSignature).to.equal(true);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it('fails when trying to create from invalid arguments', function () {
|
|
43
|
+
expect(function () {
|
|
44
|
+
return new TransactionSignature();
|
|
45
|
+
}).to.throw(errors.InvalidArgument);
|
|
46
|
+
expect(function () {
|
|
47
|
+
return new TransactionSignature(1);
|
|
48
|
+
}).to.throw(errors.InvalidArgument);
|
|
49
|
+
expect(function () {
|
|
50
|
+
return new TransactionSignature('hello world');
|
|
51
|
+
}).to.throw(errors.InvalidArgument);
|
|
52
|
+
});
|
|
53
|
+
it('returns the same object if called with a TransactionSignature', function () {
|
|
54
|
+
var signature = getSignatureFromTransaction();
|
|
55
|
+
expect(new TransactionSignature(signature)).to.equal(signature);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
it('can be aplied to a Transaction with Transaction#addSignature', function () {
|
|
59
|
+
var transaction = new Transaction();
|
|
60
|
+
transaction.from(simpleUtxoWith100000Satoshis);
|
|
61
|
+
var signature = transaction.getSignatures(privateKey)[0];
|
|
62
|
+
var addSignature = function () {
|
|
63
|
+
return transaction.applySignature(signature);
|
|
64
|
+
};
|
|
65
|
+
expect(signature instanceof TransactionSignature).to.equal(true);
|
|
66
|
+
expect(addSignature).to.not.throw();
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
describe('serialization', function () {
|
|
70
|
+
it('serializes to an object and roundtrips correctly', function () {
|
|
71
|
+
var signature = getSignatureFromTransaction();
|
|
72
|
+
var serialized = signature.toObject();
|
|
73
|
+
expect(new TransactionSignature(serialized).toObject()).to.deep.equal(serialized);
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
it('can be deserialized with fromObject', function () {
|
|
77
|
+
var signature = getSignatureFromTransaction();
|
|
78
|
+
var serialized = signature.toObject();
|
|
79
|
+
expect(TransactionSignature.fromObject(serialized).toObject()).to.deep.equal(serialized);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
it('can deserialize when signature is a buffer', function () {
|
|
83
|
+
var signature = getSignatureFromTransaction();
|
|
84
|
+
var serialized = signature.toObject();
|
|
85
|
+
serialized.signature = Buffer.from(serialized.signature, 'hex');
|
|
86
|
+
expect(TransactionSignature.fromObject(serialized).toObject()).to.deep.equal(
|
|
87
|
+
signature.toObject(),
|
|
88
|
+
);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it('can roundtrip to/from json', function () {
|
|
92
|
+
var signature = getSignatureFromTransaction();
|
|
93
|
+
var serialized = signature.toObject();
|
|
94
|
+
var json = JSON.stringify(signature);
|
|
95
|
+
expect(TransactionSignature(JSON.parse(json)).toObject()).to.deep.equal(serialized);
|
|
96
|
+
expect(TransactionSignature.fromObject(JSON.parse(json)).toObject()).to.deep.equal(
|
|
97
|
+
serialized,
|
|
98
|
+
);
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
it('can parse a previously known json string', function () {
|
|
102
|
+
var str = JSON.stringify(TransactionSignature(JSON.parse(testJSON)));
|
|
103
|
+
expect(JSON.parse(str)).to.deep.equal(JSON.parse(testJSON));
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
it('can deserialize a previously known object', function () {
|
|
107
|
+
expect(TransactionSignature(testObject).toObject()).to.deep.equal(testObject);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
var testJSON =
|
|
112
|
+
'{"publicKey":"0223078d2942df62c45621d209fab84ea9a7a23346201b7727b9b45a29c4e76f5e","prevTxId":"a477af6b2667c29670467e4e0728b685ee07b240235771862318e29ddbe58458","outputIndex":0,"inputIndex":0,"signature":"3045022100c728eac064154edba15d4f3e6cbd9be6da3498f80a783ab3391f992b4d9d71ca0220729eff4564dc06aa1d80ab73100540fe5ebb6f280b4a87bc32399f861a7b2563","sigtype":1}';
|
|
113
|
+
var testObject = JSON.parse(testJSON);
|
|
114
|
+
});
|