@bitgo-beta/abstract-eth 1.2.3-alpha.33 → 1.2.3-alpha.330
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/CHANGELOG.md +1667 -0
- package/dist/src/abstractEthLikeCoin.d.ts +18 -9
- package/dist/src/abstractEthLikeCoin.d.ts.map +1 -1
- package/dist/src/abstractEthLikeCoin.js +39 -15
- package/dist/src/abstractEthLikeNewCoins.d.ts +696 -0
- package/dist/src/abstractEthLikeNewCoins.d.ts.map +1 -0
- package/dist/src/abstractEthLikeNewCoins.js +2092 -0
- package/dist/src/ethLikeToken.d.ts +36 -6
- package/dist/src/ethLikeToken.d.ts.map +1 -1
- package/dist/src/ethLikeToken.js +286 -10
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +8 -2
- package/dist/src/lib/contractCall.d.ts +8 -0
- package/dist/src/lib/contractCall.d.ts.map +1 -0
- package/dist/src/lib/contractCall.js +17 -0
- package/dist/src/lib/iface.d.ts +133 -0
- package/dist/src/lib/iface.d.ts.map +1 -0
- package/dist/src/lib/iface.js +8 -0
- package/dist/src/lib/index.d.ts +15 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +56 -0
- package/dist/src/lib/keyPair.d.ts +26 -0
- package/dist/src/lib/keyPair.d.ts.map +1 -0
- package/dist/src/lib/keyPair.js +65 -0
- package/dist/src/lib/messages/eip191/eip191Message.d.ts +12 -0
- package/dist/src/lib/messages/eip191/eip191Message.d.ts.map +1 -0
- package/dist/src/lib/messages/eip191/eip191Message.js +27 -0
- package/dist/src/lib/messages/eip191/eip191MessageBuilder.d.ts +25 -0
- package/dist/src/lib/messages/eip191/eip191MessageBuilder.d.ts.map +1 -0
- package/dist/src/lib/messages/eip191/eip191MessageBuilder.js +68 -0
- package/dist/src/lib/messages/index.d.ts +2 -0
- package/dist/src/lib/messages/index.d.ts.map +1 -0
- package/dist/src/lib/messages/index.js +18 -0
- package/dist/src/lib/messages/messageBuilderFactory.d.ts +7 -0
- package/dist/src/lib/messages/messageBuilderFactory.d.ts.map +1 -0
- package/dist/src/lib/messages/messageBuilderFactory.js +20 -0
- package/dist/src/lib/transaction.d.ts +67 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +142 -0
- package/dist/src/lib/transactionBuilder.d.ts +251 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +742 -0
- package/dist/src/lib/transferBuilder.d.ts +76 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transferBuilder.js +307 -0
- package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts +54 -0
- package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.js +120 -0
- package/dist/src/lib/transferBuilders/index.d.ts +4 -0
- package/dist/src/lib/transferBuilders/index.d.ts.map +1 -0
- package/dist/src/lib/transferBuilders/index.js +20 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts +17 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts.map +1 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC1155.js +96 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts +16 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts.map +1 -0
- package/dist/src/lib/transferBuilders/transferBuilderERC721.js +81 -0
- package/dist/src/lib/types.d.ts +39 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +137 -0
- package/dist/src/lib/utils.d.ts +270 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +717 -0
- package/dist/src/lib/walletUtil.d.ts +32 -0
- package/dist/src/lib/walletUtil.d.ts.map +1 -0
- package/dist/src/lib/walletUtil.js +35 -0
- package/dist/src/types.d.ts +9 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +3 -0
- package/dist/test/index.d.ts +2 -0
- package/dist/test/index.d.ts.map +1 -0
- package/dist/test/index.js +18 -0
- package/dist/test/unit/coin.d.ts +8 -0
- package/dist/test/unit/coin.d.ts.map +1 -0
- package/dist/test/unit/coin.js +577 -0
- package/dist/test/unit/index.d.ts +6 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +22 -0
- package/dist/test/unit/messages/eip191/eip191Message.d.ts +2 -0
- package/dist/test/unit/messages/eip191/eip191Message.d.ts.map +1 -0
- package/dist/test/unit/messages/eip191/eip191Message.js +148 -0
- package/dist/test/unit/messages/eip191/eip191MessageBuilder.d.ts +2 -0
- package/dist/test/unit/messages/eip191/eip191MessageBuilder.d.ts.map +1 -0
- package/dist/test/unit/messages/eip191/eip191MessageBuilder.js +106 -0
- package/dist/test/unit/messages/fixtures.d.ts +19 -0
- package/dist/test/unit/messages/fixtures.d.ts.map +1 -0
- package/dist/test/unit/messages/fixtures.js +25 -0
- package/dist/test/unit/messages/index.d.ts +4 -0
- package/dist/test/unit/messages/index.d.ts.map +1 -0
- package/dist/test/unit/messages/index.js +20 -0
- package/dist/test/unit/messages/messageBuilderFactory.d.ts +2 -0
- package/dist/test/unit/messages/messageBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/messages/messageBuilderFactory.js +45 -0
- package/dist/test/unit/token.d.ts +2 -0
- package/dist/test/unit/token.d.ts.map +1 -0
- package/dist/test/unit/token.js +37 -0
- package/dist/test/unit/transaction.d.ts +3 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +60 -0
- package/dist/test/unit/transactionBuilder/addressInitialization.d.ts +8 -0
- package/dist/test/unit/transactionBuilder/addressInitialization.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/addressInitialization.js +95 -0
- package/dist/test/unit/transactionBuilder/index.d.ts +4 -0
- package/dist/test/unit/transactionBuilder/index.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/index.js +20 -0
- package/dist/test/unit/transactionBuilder/send.d.ts +3 -0
- package/dist/test/unit/transactionBuilder/send.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/send.js +197 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.d.ts +10 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/walletInitialization.js +124 -0
- package/dist/test/unit/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transferBuilder.js +76 -0
- package/dist/tsconfig.tsbuildinfo +1 -8236
- package/index.ts +2 -0
- package/package.json +29 -9
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../test/unit/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,SAAS,CAAC;AACxB,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./transactionBuilder"), exports);
|
|
18
|
+
__exportStar(require("./token"), exports);
|
|
19
|
+
__exportStar(require("./transaction"), exports);
|
|
20
|
+
__exportStar(require("./coin"), exports);
|
|
21
|
+
__exportStar(require("./messages"), exports);
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90ZXN0L3VuaXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHVEQUFxQztBQUNyQywwQ0FBd0I7QUFDeEIsZ0RBQThCO0FBQzlCLHlDQUF1QjtBQUN2Qiw2Q0FBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL3Rva2VuJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9jb2luJztcbmV4cG9ydCAqIGZyb20gJy4vbWVzc2FnZXMnO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eip191Message.d.ts","sourceRoot":"","sources":["../../../../../test/unit/messages/eip191/eip191Message.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,CAAC"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
require("should");
|
|
7
|
+
const sinon_1 = __importDefault(require("sinon"));
|
|
8
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
9
|
+
const fixtures_1 = require("../fixtures");
|
|
10
|
+
const eip191Message_1 = require("../../../../src/lib/messages/eip191/eip191Message");
|
|
11
|
+
describe('EIP191 Message', () => {
|
|
12
|
+
const sandbox = sinon_1.default.createSandbox();
|
|
13
|
+
afterEach(() => {
|
|
14
|
+
sandbox.restore();
|
|
15
|
+
});
|
|
16
|
+
it('should initialize with the correct type', () => {
|
|
17
|
+
const message = new eip191Message_1.EIP191Message({
|
|
18
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
19
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
20
|
+
});
|
|
21
|
+
message.getType().should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
22
|
+
});
|
|
23
|
+
it('should generate the correct signable payload with Ethereum prefix', async () => {
|
|
24
|
+
const message = new eip191Message_1.EIP191Message({
|
|
25
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
26
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
27
|
+
});
|
|
28
|
+
const signablePayload = await message.getSignablePayload();
|
|
29
|
+
// Message is prefixed with "\u0019Ethereum Signed Message:\n<length><message>"
|
|
30
|
+
const expectedPrefix = `\u0019Ethereum Signed Message:\n${fixtures_1.fixtures.messages.validMessage.length}`;
|
|
31
|
+
const expectedPayload = Buffer.from(expectedPrefix.concat(fixtures_1.fixtures.messages.validMessage)).toString('hex');
|
|
32
|
+
signablePayload.should.equal(expectedPayload);
|
|
33
|
+
});
|
|
34
|
+
it('should handle empty messages correctly', async () => {
|
|
35
|
+
const message = new eip191Message_1.EIP191Message({
|
|
36
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
37
|
+
payload: fixtures_1.fixtures.messages.emptyMessage,
|
|
38
|
+
});
|
|
39
|
+
const signablePayload = await message.getSignablePayload();
|
|
40
|
+
// Empty message has length 0
|
|
41
|
+
const expectedPrefix = `\u0019Ethereum Signed Message:\n0`;
|
|
42
|
+
const expectedPayload = Buffer.from(expectedPrefix.concat('')).toString('hex');
|
|
43
|
+
signablePayload.should.equal(expectedPayload);
|
|
44
|
+
});
|
|
45
|
+
it('should handle messages with special characters', async () => {
|
|
46
|
+
const message = new eip191Message_1.EIP191Message({
|
|
47
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
48
|
+
payload: fixtures_1.fixtures.messages.specialCharsMessage,
|
|
49
|
+
});
|
|
50
|
+
const signablePayload = await message.getSignablePayload();
|
|
51
|
+
const expectedPrefix = `\u0019Ethereum Signed Message:\n${fixtures_1.fixtures.messages.specialCharsMessage.length}`;
|
|
52
|
+
const expectedPayload = Buffer.from(expectedPrefix.concat(fixtures_1.fixtures.messages.specialCharsMessage)).toString('hex');
|
|
53
|
+
signablePayload.should.equal(expectedPayload);
|
|
54
|
+
});
|
|
55
|
+
it('should reuse existing signable payload if already set', async () => {
|
|
56
|
+
const message = new eip191Message_1.EIP191Message({
|
|
57
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
58
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
59
|
+
signablePayload: 'predefined-payload',
|
|
60
|
+
});
|
|
61
|
+
const signablePayload = await message.getSignablePayload();
|
|
62
|
+
signablePayload.should.equal('predefined-payload');
|
|
63
|
+
});
|
|
64
|
+
it('should maintain signatures and signers correctly', () => {
|
|
65
|
+
const message = new eip191Message_1.EIP191Message({
|
|
66
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
67
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
68
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
69
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
70
|
+
});
|
|
71
|
+
message.getSignatures().should.containEql(fixtures_1.fixtures.eip191.signature);
|
|
72
|
+
message.getSigners().should.containEql(fixtures_1.fixtures.eip191.signer);
|
|
73
|
+
// Test adding new ones
|
|
74
|
+
message.addSignature('new-signature');
|
|
75
|
+
message.addSigner('new-signer');
|
|
76
|
+
message.getSignatures().should.containEql('new-signature');
|
|
77
|
+
message.getSigners().should.containEql('new-signer');
|
|
78
|
+
// Test replacing all
|
|
79
|
+
message.setSignatures(['replaced-signature']);
|
|
80
|
+
message.setSigners(['replaced-signer']);
|
|
81
|
+
message.getSignatures().should.deepEqual(['replaced-signature']);
|
|
82
|
+
message.getSigners().should.deepEqual(['replaced-signer']);
|
|
83
|
+
});
|
|
84
|
+
it('should store and retrieve metadata correctly', () => {
|
|
85
|
+
const message = new eip191Message_1.EIP191Message({
|
|
86
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
87
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
88
|
+
metadata: fixtures_1.fixtures.eip191.metadata,
|
|
89
|
+
});
|
|
90
|
+
message.getMetadata().should.deepEqual(fixtures_1.fixtures.eip191.metadata);
|
|
91
|
+
});
|
|
92
|
+
describe('Broadcast Format', () => {
|
|
93
|
+
it('should convert to broadcast format correctly', async () => {
|
|
94
|
+
const message = new eip191Message_1.EIP191Message({
|
|
95
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
96
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
97
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
98
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
99
|
+
metadata: fixtures_1.fixtures.eip191.metadata,
|
|
100
|
+
signablePayload: 'test-signable-payload',
|
|
101
|
+
});
|
|
102
|
+
const broadcastFormat = await message.toBroadcastFormat();
|
|
103
|
+
broadcastFormat.type.should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
104
|
+
broadcastFormat.payload.should.equal(fixtures_1.fixtures.messages.validMessage);
|
|
105
|
+
broadcastFormat.signatures.should.deepEqual([fixtures_1.fixtures.eip191.signature]);
|
|
106
|
+
broadcastFormat.signers.should.deepEqual([fixtures_1.fixtures.eip191.signer]);
|
|
107
|
+
broadcastFormat.metadata.should.deepEqual(fixtures_1.fixtures.eip191.metadata);
|
|
108
|
+
broadcastFormat.signablePayload.should.equal('test-signable-payload');
|
|
109
|
+
});
|
|
110
|
+
it('should throw error when broadcasting without signatures', async () => {
|
|
111
|
+
const message = new eip191Message_1.EIP191Message({
|
|
112
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
113
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
114
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
115
|
+
});
|
|
116
|
+
await message
|
|
117
|
+
.toBroadcastFormat()
|
|
118
|
+
.should.be.rejectedWith('No signatures available for broadcast. Call setSignatures or addSignature first.');
|
|
119
|
+
});
|
|
120
|
+
it('should throw error when broadcasting without signers', async () => {
|
|
121
|
+
const message = new eip191Message_1.EIP191Message({
|
|
122
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
123
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
124
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
125
|
+
});
|
|
126
|
+
await message
|
|
127
|
+
.toBroadcastFormat()
|
|
128
|
+
.should.be.rejectedWith('No signers available for broadcast. Call setSigners or addSigner first.');
|
|
129
|
+
});
|
|
130
|
+
it('should convert to broadcast string correctly', async () => {
|
|
131
|
+
const message = new eip191Message_1.EIP191Message({
|
|
132
|
+
coinConfig: fixtures_1.fixtures.coin,
|
|
133
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
134
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
135
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
136
|
+
metadata: fixtures_1.fixtures.eip191.metadata,
|
|
137
|
+
});
|
|
138
|
+
const broadcastString = await message.toBroadcastString();
|
|
139
|
+
const parsedBroadcast = JSON.parse(broadcastString);
|
|
140
|
+
parsedBroadcast.type.should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
141
|
+
parsedBroadcast.payload.should.equal(fixtures_1.fixtures.messages.validMessage);
|
|
142
|
+
parsedBroadcast.signatures.should.deepEqual([fixtures_1.fixtures.eip191.signature]);
|
|
143
|
+
parsedBroadcast.signers.should.deepEqual([fixtures_1.fixtures.eip191.signer]);
|
|
144
|
+
parsedBroadcast.metadata.should.deepEqual(fixtures_1.fixtures.eip191.metadata);
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eip191Message.js","sourceRoot":"","sources":["../../../../../test/unit/messages/eip191/eip191Message.ts"],"names":[],"mappings":"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","sourcesContent":["import 'should';\nimport sinon from 'sinon';\nimport { MessageStandardType } from '@bitgo-beta/sdk-core';\nimport { fixtures } from '../fixtures';\nimport { EIP191Message } from '../../../../src/lib/messages/eip191/eip191Message';\n\ndescribe('EIP191 Message', () => {\n  const sandbox = sinon.createSandbox();\n\n  afterEach(() => {\n    sandbox.restore();\n  });\n\n  it('should initialize with the correct type', () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.validMessage,\n    });\n\n    message.getType().should.equal(MessageStandardType.EIP191);\n  });\n\n  it('should generate the correct signable payload with Ethereum prefix', async () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.validMessage,\n    });\n\n    const signablePayload = await message.getSignablePayload();\n    // Message is prefixed with \"\\u0019Ethereum Signed Message:\\n<length><message>\"\n    const expectedPrefix = `\\u0019Ethereum Signed Message:\\n${fixtures.messages.validMessage.length}`;\n    const expectedPayload = Buffer.from(expectedPrefix.concat(fixtures.messages.validMessage)).toString('hex');\n\n    signablePayload.should.equal(expectedPayload);\n  });\n\n  it('should handle empty messages correctly', async () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.emptyMessage,\n    });\n\n    const signablePayload = await message.getSignablePayload();\n    // Empty message has length 0\n    const expectedPrefix = `\\u0019Ethereum Signed Message:\\n0`;\n    const expectedPayload = Buffer.from(expectedPrefix.concat('')).toString('hex');\n\n    signablePayload.should.equal(expectedPayload);\n  });\n\n  it('should handle messages with special characters', async () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.specialCharsMessage,\n    });\n\n    const signablePayload = await message.getSignablePayload();\n    const expectedPrefix = `\\u0019Ethereum Signed Message:\\n${fixtures.messages.specialCharsMessage.length}`;\n    const expectedPayload = Buffer.from(expectedPrefix.concat(fixtures.messages.specialCharsMessage)).toString('hex');\n\n    signablePayload.should.equal(expectedPayload);\n  });\n\n  it('should reuse existing signable payload if already set', async () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.validMessage,\n      signablePayload: 'predefined-payload',\n    });\n\n    const signablePayload = await message.getSignablePayload();\n    signablePayload.should.equal('predefined-payload');\n  });\n\n  it('should maintain signatures and signers correctly', () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.validMessage,\n      signatures: [fixtures.eip191.signature],\n      signers: [fixtures.eip191.signer],\n    });\n\n    message.getSignatures().should.containEql(fixtures.eip191.signature);\n    message.getSigners().should.containEql(fixtures.eip191.signer);\n\n    // Test adding new ones\n    message.addSignature('new-signature');\n    message.addSigner('new-signer');\n\n    message.getSignatures().should.containEql('new-signature');\n    message.getSigners().should.containEql('new-signer');\n\n    // Test replacing all\n    message.setSignatures(['replaced-signature']);\n    message.setSigners(['replaced-signer']);\n\n    message.getSignatures().should.deepEqual(['replaced-signature']);\n    message.getSigners().should.deepEqual(['replaced-signer']);\n  });\n\n  it('should store and retrieve metadata correctly', () => {\n    const message = new EIP191Message({\n      coinConfig: fixtures.coin,\n      payload: fixtures.messages.validMessage,\n      metadata: fixtures.eip191.metadata,\n    });\n\n    message.getMetadata()!.should.deepEqual(fixtures.eip191.metadata);\n  });\n\n  describe('Broadcast Format', () => {\n    it('should convert to broadcast format correctly', async () => {\n      const message = new EIP191Message({\n        coinConfig: fixtures.coin,\n        payload: fixtures.messages.validMessage,\n        signatures: [fixtures.eip191.signature],\n        signers: [fixtures.eip191.signer],\n        metadata: fixtures.eip191.metadata,\n        signablePayload: 'test-signable-payload',\n      });\n\n      const broadcastFormat = await message.toBroadcastFormat();\n\n      broadcastFormat.type.should.equal(MessageStandardType.EIP191);\n      broadcastFormat.payload.should.equal(fixtures.messages.validMessage);\n      broadcastFormat.signatures.should.deepEqual([fixtures.eip191.signature]);\n      broadcastFormat.signers.should.deepEqual([fixtures.eip191.signer]);\n      broadcastFormat.metadata!.should.deepEqual(fixtures.eip191.metadata);\n      broadcastFormat.signablePayload!.should.equal('test-signable-payload');\n    });\n\n    it('should throw error when broadcasting without signatures', async () => {\n      const message = new EIP191Message({\n        coinConfig: fixtures.coin,\n        payload: fixtures.messages.validMessage,\n        signers: [fixtures.eip191.signer],\n      });\n\n      await message\n        .toBroadcastFormat()\n        .should.be.rejectedWith('No signatures available for broadcast. Call setSignatures or addSignature first.');\n    });\n\n    it('should throw error when broadcasting without signers', async () => {\n      const message = new EIP191Message({\n        coinConfig: fixtures.coin,\n        payload: fixtures.messages.validMessage,\n        signatures: [fixtures.eip191.signature],\n      });\n\n      await message\n        .toBroadcastFormat()\n        .should.be.rejectedWith('No signers available for broadcast. Call setSigners or addSigner first.');\n    });\n\n    it('should convert to broadcast string correctly', async () => {\n      const message = new EIP191Message({\n        coinConfig: fixtures.coin,\n        payload: fixtures.messages.validMessage,\n        signatures: [fixtures.eip191.signature],\n        signers: [fixtures.eip191.signer],\n        metadata: fixtures.eip191.metadata,\n      });\n\n      const broadcastString = await message.toBroadcastString();\n      const parsedBroadcast = JSON.parse(broadcastString);\n\n      parsedBroadcast.type.should.equal(MessageStandardType.EIP191);\n      parsedBroadcast.payload.should.equal(fixtures.messages.validMessage);\n      parsedBroadcast.signatures.should.deepEqual([fixtures.eip191.signature]);\n      parsedBroadcast.signers.should.deepEqual([fixtures.eip191.signer]);\n      parsedBroadcast.metadata.should.deepEqual(fixtures.eip191.metadata);\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eip191MessageBuilder.d.ts","sourceRoot":"","sources":["../../../../../test/unit/messages/eip191/eip191MessageBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,CAAC"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
require("should");
|
|
7
|
+
const sinon_1 = __importDefault(require("sinon"));
|
|
8
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
9
|
+
const fixtures_1 = require("../fixtures");
|
|
10
|
+
const eip191Message_1 = require("../../../../src/lib/messages/eip191/eip191Message");
|
|
11
|
+
const eip191MessageBuilder_1 = require("../../../../src/lib/messages/eip191/eip191MessageBuilder");
|
|
12
|
+
describe('EIP191 Message Builder', () => {
|
|
13
|
+
const sandbox = sinon_1.default.createSandbox();
|
|
14
|
+
afterEach(() => {
|
|
15
|
+
sandbox.restore();
|
|
16
|
+
});
|
|
17
|
+
describe('constructor', () => {
|
|
18
|
+
it('should initialize with the correct message type', () => {
|
|
19
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
20
|
+
// Test the builder's private property indirectly through build()
|
|
21
|
+
builder.should.be.instanceof(eip191MessageBuilder_1.Eip191MessageBuilder);
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
describe('build method', () => {
|
|
25
|
+
it('should build a valid EIP191 message', async () => {
|
|
26
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
27
|
+
builder.setPayload(fixtures_1.fixtures.messages.validMessage).setMetadata({ customData: 'test data' });
|
|
28
|
+
const message = await builder.build();
|
|
29
|
+
message.should.be.instanceof(eip191Message_1.EIP191Message);
|
|
30
|
+
message.getType().should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
31
|
+
message.getPayload().should.equal(fixtures_1.fixtures.messages.validMessage);
|
|
32
|
+
message.getMetadata().should.have.property('customData', 'test data');
|
|
33
|
+
message.getMetadata().should.have.property('encoding', 'utf8');
|
|
34
|
+
});
|
|
35
|
+
it('should throw an error when building without setting payload', async () => {
|
|
36
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
37
|
+
await builder.build().should.be.rejectedWith('Message payload must be set before building the message');
|
|
38
|
+
});
|
|
39
|
+
it('should include signers when building a message', async () => {
|
|
40
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
41
|
+
builder.setPayload(fixtures_1.fixtures.messages.validMessage);
|
|
42
|
+
builder.addSigner(fixtures_1.fixtures.eip191.signer);
|
|
43
|
+
const message = await builder.build();
|
|
44
|
+
message.getSigners().should.containEql(fixtures_1.fixtures.eip191.signer);
|
|
45
|
+
});
|
|
46
|
+
it('should include signatures when building a message', async () => {
|
|
47
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
48
|
+
builder.setPayload(fixtures_1.fixtures.messages.validMessage);
|
|
49
|
+
builder.addSignature(fixtures_1.fixtures.eip191.signature);
|
|
50
|
+
const message = await builder.build();
|
|
51
|
+
message.getSignatures().should.containEql(fixtures_1.fixtures.eip191.signature);
|
|
52
|
+
});
|
|
53
|
+
it('should override metadata.encoding with utf8', async () => {
|
|
54
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
55
|
+
builder.setPayload(fixtures_1.fixtures.messages.validMessage);
|
|
56
|
+
builder.setMetadata({ encoding: 'hex', customData: 'test data' });
|
|
57
|
+
const message = await builder.build();
|
|
58
|
+
message.getMetadata().should.have.property('encoding', 'utf8');
|
|
59
|
+
message.getMetadata().should.have.property('customData', 'test data');
|
|
60
|
+
});
|
|
61
|
+
it('should handle error scenarios gracefully', async () => {
|
|
62
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
63
|
+
// Force an error by using stub
|
|
64
|
+
const buildStub = sandbox.stub(builder, 'build');
|
|
65
|
+
buildStub.throws(new Error('Test error'));
|
|
66
|
+
await builder.build().should.be.rejectedWith('Test error');
|
|
67
|
+
// Force a non-Error object to be thrown
|
|
68
|
+
buildStub.throws('String error');
|
|
69
|
+
await builder.build().should.be.rejectedWith('Failed to build EIP-191 message');
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
describe('fromBroadcastFormat method', () => {
|
|
73
|
+
it('should reconstruct a message from broadcast format', async () => {
|
|
74
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
75
|
+
const broadcastMessage = {
|
|
76
|
+
type: sdk_core_1.MessageStandardType.EIP191,
|
|
77
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
78
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
79
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
80
|
+
metadata: fixtures_1.fixtures.eip191.metadata,
|
|
81
|
+
};
|
|
82
|
+
const message = await builder.fromBroadcastFormat(broadcastMessage);
|
|
83
|
+
message.should.be.instanceof(eip191Message_1.EIP191Message);
|
|
84
|
+
message.getType().should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
85
|
+
message.getPayload().should.equal(fixtures_1.fixtures.messages.validMessage);
|
|
86
|
+
message.getSignatures().should.containEql(fixtures_1.fixtures.eip191.signature);
|
|
87
|
+
message.getSigners().should.containEql(fixtures_1.fixtures.eip191.signer);
|
|
88
|
+
message.getMetadata().should.have.property('encoding', 'utf8');
|
|
89
|
+
message.getMetadata().should.have.property('customData', 'test data');
|
|
90
|
+
});
|
|
91
|
+
it('should throw an error for incorrect message type', async () => {
|
|
92
|
+
const builder = new eip191MessageBuilder_1.Eip191MessageBuilder(fixtures_1.fixtures.coin);
|
|
93
|
+
const broadcastMessage = {
|
|
94
|
+
type: sdk_core_1.MessageStandardType.UNKNOWN,
|
|
95
|
+
payload: fixtures_1.fixtures.messages.validMessage,
|
|
96
|
+
signatures: [fixtures_1.fixtures.eip191.signature],
|
|
97
|
+
signers: [fixtures_1.fixtures.eip191.signer],
|
|
98
|
+
metadata: {},
|
|
99
|
+
};
|
|
100
|
+
await builder
|
|
101
|
+
.fromBroadcastFormat(broadcastMessage)
|
|
102
|
+
.should.be.rejectedWith(`Invalid message type, expected ${sdk_core_1.MessageStandardType.EIP191}`);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eip191MessageBuilder.js","sourceRoot":"","sources":["../../../../../test/unit/messages/eip191/eip191MessageBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import 'should';\nimport sinon from 'sinon';\nimport { MessageStandardType } from '@bitgo-beta/sdk-core';\nimport { fixtures } from '../fixtures';\nimport { EIP191Message } from '../../../../src/lib/messages/eip191/eip191Message';\nimport { Eip191MessageBuilder } from '../../../../src/lib/messages/eip191/eip191MessageBuilder';\n\ndescribe('EIP191 Message Builder', () => {\n  const sandbox = sinon.createSandbox();\n\n  afterEach(() => {\n    sandbox.restore();\n  });\n\n  describe('constructor', () => {\n    it('should initialize with the correct message type', () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n      // Test the builder's private property indirectly through build()\n      builder.should.be.instanceof(Eip191MessageBuilder);\n    });\n  });\n\n  describe('build method', () => {\n    it('should build a valid EIP191 message', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      builder.setPayload(fixtures.messages.validMessage).setMetadata({ customData: 'test data' });\n\n      const message = await builder.build();\n\n      message.should.be.instanceof(EIP191Message);\n      message.getType().should.equal(MessageStandardType.EIP191);\n      message.getPayload().should.equal(fixtures.messages.validMessage);\n      message.getMetadata()!.should.have.property('customData', 'test data');\n      message.getMetadata()!.should.have.property('encoding', 'utf8');\n    });\n\n    it('should throw an error when building without setting payload', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      await builder.build().should.be.rejectedWith('Message payload must be set before building the message');\n    });\n\n    it('should include signers when building a message', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      builder.setPayload(fixtures.messages.validMessage);\n      builder.addSigner(fixtures.eip191.signer);\n\n      const message = await builder.build();\n\n      message.getSigners().should.containEql(fixtures.eip191.signer);\n    });\n\n    it('should include signatures when building a message', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      builder.setPayload(fixtures.messages.validMessage);\n      builder.addSignature(fixtures.eip191.signature);\n\n      const message = await builder.build();\n\n      message.getSignatures().should.containEql(fixtures.eip191.signature);\n    });\n\n    it('should override metadata.encoding with utf8', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      builder.setPayload(fixtures.messages.validMessage);\n      builder.setMetadata({ encoding: 'hex', customData: 'test data' });\n\n      const message = await builder.build();\n\n      message.getMetadata()!.should.have.property('encoding', 'utf8');\n      message.getMetadata()!.should.have.property('customData', 'test data');\n    });\n\n    it('should handle error scenarios gracefully', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      // Force an error by using stub\n      const buildStub = sandbox.stub(builder, 'build' as any);\n      buildStub.throws(new Error('Test error'));\n\n      await builder.build().should.be.rejectedWith('Test error');\n\n      // Force a non-Error object to be thrown\n      buildStub.throws('String error');\n\n      await builder.build().should.be.rejectedWith('Failed to build EIP-191 message');\n    });\n  });\n\n  describe('fromBroadcastFormat method', () => {\n    it('should reconstruct a message from broadcast format', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      const broadcastMessage = {\n        type: MessageStandardType.EIP191,\n        payload: fixtures.messages.validMessage,\n        signatures: [fixtures.eip191.signature],\n        signers: [fixtures.eip191.signer],\n        metadata: fixtures.eip191.metadata,\n      };\n\n      const message = await builder.fromBroadcastFormat(broadcastMessage);\n\n      message.should.be.instanceof(EIP191Message);\n      message.getType().should.equal(MessageStandardType.EIP191);\n      message.getPayload().should.equal(fixtures.messages.validMessage);\n      message.getSignatures().should.containEql(fixtures.eip191.signature);\n      message.getSigners().should.containEql(fixtures.eip191.signer);\n      message.getMetadata()!.should.have.property('encoding', 'utf8');\n      message.getMetadata()!.should.have.property('customData', 'test data');\n    });\n\n    it('should throw an error for incorrect message type', async () => {\n      const builder = new Eip191MessageBuilder(fixtures.coin);\n\n      const broadcastMessage = {\n        type: MessageStandardType.UNKNOWN,\n        payload: fixtures.messages.validMessage,\n        signatures: [fixtures.eip191.signature],\n        signers: [fixtures.eip191.signer],\n        metadata: {},\n      };\n\n      await builder\n        .fromBroadcastFormat(broadcastMessage)\n        .should.be.rejectedWith(`Invalid message type, expected ${MessageStandardType.EIP191}`);\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export declare const fixtures: {
|
|
2
|
+
coin: Readonly<import("@bitgo-beta/statics").BaseCoin>;
|
|
3
|
+
messages: {
|
|
4
|
+
validMessage: string;
|
|
5
|
+
emptyMessage: string;
|
|
6
|
+
specialCharsMessage: string;
|
|
7
|
+
longMessage: string;
|
|
8
|
+
};
|
|
9
|
+
eip191: {
|
|
10
|
+
validSignablePayload: string;
|
|
11
|
+
signature: string;
|
|
12
|
+
signer: string;
|
|
13
|
+
metadata: {
|
|
14
|
+
encoding: string;
|
|
15
|
+
customData: string;
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=fixtures.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fixtures.d.ts","sourceRoot":"","sources":["../../../../test/unit/messages/fixtures.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;CAoBpB,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.fixtures = void 0;
|
|
4
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
5
|
+
// Test fixtures for EIP-191 message tests
|
|
6
|
+
exports.fixtures = {
|
|
7
|
+
coin: statics_1.coins.get('teth'),
|
|
8
|
+
messages: {
|
|
9
|
+
validMessage: 'Hello, world!',
|
|
10
|
+
emptyMessage: '',
|
|
11
|
+
specialCharsMessage: '!@#$%^&*()',
|
|
12
|
+
longMessage: 'This is a very long message that contains multiple lines and special characters. ' +
|
|
13
|
+
'It is designed to test the EIP-191 message format with a more complex payload.',
|
|
14
|
+
},
|
|
15
|
+
eip191: {
|
|
16
|
+
validSignablePayload: '0x19457468657265756d205369676e6564204d6573736167653a0d48656c6c6f2c20776f726c6421',
|
|
17
|
+
signature: '0x5d99b6f7f6d1f73d1a26497f2b1c89b24c0993913f86e9a2d02cd69887d9c94f3c880358579d811b21dd1b7fd9bb01c1d81d10e69f0384e675c32b39643be8921b',
|
|
18
|
+
signer: '0x7E5F4552091A69125d5DfCb7b8C2659029395Bdf',
|
|
19
|
+
metadata: {
|
|
20
|
+
encoding: 'utf8',
|
|
21
|
+
customData: 'test data',
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4dHVyZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0L3VuaXQvbWVzc2FnZXMvZml4dHVyZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsaURBQTRDO0FBRTVDLDBDQUEwQztBQUM3QixRQUFBLFFBQVEsR0FBRztJQUN0QixJQUFJLEVBQUUsZUFBSyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUM7SUFDdkIsUUFBUSxFQUFFO1FBQ1IsWUFBWSxFQUFFLGVBQWU7UUFDN0IsWUFBWSxFQUFFLEVBQUU7UUFDaEIsbUJBQW1CLEVBQUUsWUFBWTtRQUNqQyxXQUFXLEVBQ1QsbUZBQW1GO1lBQ25GLGdGQUFnRjtLQUNuRjtJQUNELE1BQU0sRUFBRTtRQUNOLG9CQUFvQixFQUFFLGtGQUFrRjtRQUN4RyxTQUFTLEVBQ1Asc0lBQXNJO1FBQ3hJLE1BQU0sRUFBRSw0Q0FBNEM7UUFDcEQsUUFBUSxFQUFFO1lBQ1IsUUFBUSxFQUFFLE1BQU07WUFDaEIsVUFBVSxFQUFFLFdBQVc7U0FDeEI7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb2lucyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuXG4vLyBUZXN0IGZpeHR1cmVzIGZvciBFSVAtMTkxIG1lc3NhZ2UgdGVzdHNcbmV4cG9ydCBjb25zdCBmaXh0dXJlcyA9IHtcbiAgY29pbjogY29pbnMuZ2V0KCd0ZXRoJyksXG4gIG1lc3NhZ2VzOiB7XG4gICAgdmFsaWRNZXNzYWdlOiAnSGVsbG8sIHdvcmxkIScsXG4gICAgZW1wdHlNZXNzYWdlOiAnJyxcbiAgICBzcGVjaWFsQ2hhcnNNZXNzYWdlOiAnIUAjJCVeJiooKScsXG4gICAgbG9uZ01lc3NhZ2U6XG4gICAgICAnVGhpcyBpcyBhIHZlcnkgbG9uZyBtZXNzYWdlIHRoYXQgY29udGFpbnMgbXVsdGlwbGUgbGluZXMgYW5kIHNwZWNpYWwgY2hhcmFjdGVycy4gJyArXG4gICAgICAnSXQgaXMgZGVzaWduZWQgdG8gdGVzdCB0aGUgRUlQLTE5MSBtZXNzYWdlIGZvcm1hdCB3aXRoIGEgbW9yZSBjb21wbGV4IHBheWxvYWQuJyxcbiAgfSxcbiAgZWlwMTkxOiB7XG4gICAgdmFsaWRTaWduYWJsZVBheWxvYWQ6ICcweDE5NDU3NDY4NjU3MjY1NzU2ZDIwNTM2OTY3NmU2NTY0MjA0ZDY1NzM3MzYxNjc2NTNhMGQ0ODY1NmM2YzZmMmMyMDc3NmY3MjZjNjQyMScsXG4gICAgc2lnbmF0dXJlOlxuICAgICAgJzB4NWQ5OWI2ZjdmNmQxZjczZDFhMjY0OTdmMmIxYzg5YjI0YzA5OTM5MTNmODZlOWEyZDAyY2Q2OTg4N2Q5Yzk0ZjNjODgwMzU4NTc5ZDgxMWIyMWRkMWI3ZmQ5YmIwMWMxZDgxZDEwZTY5ZjAzODRlNjc1YzMyYjM5NjQzYmU4OTIxYicsXG4gICAgc2lnbmVyOiAnMHg3RTVGNDU1MjA5MUE2OTEyNWQ1RGZDYjdiOEMyNjU5MDI5Mzk1QmRmJyxcbiAgICBtZXRhZGF0YToge1xuICAgICAgZW5jb2Rpbmc6ICd1dGY4JyxcbiAgICAgIGN1c3RvbURhdGE6ICd0ZXN0IGRhdGEnLFxuICAgIH0sXG4gIH0sXG59O1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../test/unit/messages/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./eip191/eip191Message"), exports);
|
|
18
|
+
__exportStar(require("./eip191/eip191MessageBuilder"), exports);
|
|
19
|
+
__exportStar(require("./messageBuilderFactory"), exports);
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi90ZXN0L3VuaXQvbWVzc2FnZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlEQUF1QztBQUN2QyxnRUFBOEM7QUFDOUMsMERBQXdDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9laXAxOTEvZWlwMTkxTWVzc2FnZSc7XG5leHBvcnQgKiBmcm9tICcuL2VpcDE5MS9laXAxOTFNZXNzYWdlQnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL21lc3NhZ2VCdWlsZGVyRmFjdG9yeSc7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messageBuilderFactory.d.ts","sourceRoot":"","sources":["../../../../test/unit/messages/messageBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
require("should");
|
|
7
|
+
const sinon_1 = __importDefault(require("sinon"));
|
|
8
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
9
|
+
const fixtures_1 = require("./fixtures");
|
|
10
|
+
const messages_1 = require("../../../src/lib/messages");
|
|
11
|
+
const eip191MessageBuilder_1 = require("../../../src/lib/messages/eip191/eip191MessageBuilder");
|
|
12
|
+
describe('Message Builder Factory', () => {
|
|
13
|
+
const sandbox = sinon_1.default.createSandbox();
|
|
14
|
+
afterEach(() => {
|
|
15
|
+
sandbox.restore();
|
|
16
|
+
});
|
|
17
|
+
describe('getMessageBuilder', () => {
|
|
18
|
+
it('should return the correct builder for EIP191 message type', () => {
|
|
19
|
+
const factory = new messages_1.MessageBuilderFactory(fixtures_1.fixtures.coin);
|
|
20
|
+
const builder = factory.getMessageBuilder(sdk_core_1.MessageStandardType.EIP191);
|
|
21
|
+
builder.should.be.instanceof(eip191MessageBuilder_1.Eip191MessageBuilder);
|
|
22
|
+
});
|
|
23
|
+
it('should throw an error for unsupported message types', () => {
|
|
24
|
+
const factory = new messages_1.MessageBuilderFactory(fixtures_1.fixtures.coin);
|
|
25
|
+
// Test with an invalid/unsupported message type
|
|
26
|
+
const unsupportedType = 'UNSUPPORTED_TYPE';
|
|
27
|
+
(() => factory.getMessageBuilder(unsupportedType)).should.throw(/Invalid message standard/);
|
|
28
|
+
});
|
|
29
|
+
it('should throw for unknown message standard', () => {
|
|
30
|
+
const factory = new messages_1.MessageBuilderFactory(fixtures_1.fixtures.coin);
|
|
31
|
+
(() => factory.getMessageBuilder(sdk_core_1.MessageStandardType.UNKNOWN)).should.throw(`Invalid message standard ${sdk_core_1.MessageStandardType.UNKNOWN}`);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
describe('Integration with builder', () => {
|
|
35
|
+
it('should create a builder that can build a valid message', async () => {
|
|
36
|
+
const factory = new messages_1.MessageBuilderFactory(fixtures_1.fixtures.coin);
|
|
37
|
+
const builder = factory.getMessageBuilder(sdk_core_1.MessageStandardType.EIP191);
|
|
38
|
+
builder.setPayload(fixtures_1.fixtures.messages.validMessage);
|
|
39
|
+
const message = await builder.build();
|
|
40
|
+
message.getType().should.equal(sdk_core_1.MessageStandardType.EIP191);
|
|
41
|
+
message.getPayload().should.equal(fixtures_1.fixtures.messages.validMessage);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZUJ1aWxkZXJGYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC91bml0L21lc3NhZ2VzL21lc3NhZ2VCdWlsZGVyRmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGtCQUFnQjtBQUNoQixrREFBMEI7QUFDMUIsbURBQTJEO0FBQzNELHlDQUFzQztBQUN0Qyx3REFBa0U7QUFDbEUsZ0dBQTZGO0FBRTdGLFFBQVEsQ0FBQyx5QkFBeUIsRUFBRSxHQUFHLEVBQUU7SUFDdkMsTUFBTSxPQUFPLEdBQUcsZUFBSyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBRXRDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDYixPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDcEIsQ0FBQyxDQUFDLENBQUM7SUFFSCxRQUFRLENBQUMsbUJBQW1CLEVBQUUsR0FBRyxFQUFFO1FBQ2pDLEVBQUUsQ0FBQywyREFBMkQsRUFBRSxHQUFHLEVBQUU7WUFDbkUsTUFBTSxPQUFPLEdBQUcsSUFBSSxnQ0FBcUIsQ0FBQyxtQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRXpELE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyw4QkFBbUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUV0RSxPQUFPLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsMkNBQW9CLENBQUMsQ0FBQztRQUNyRCxDQUFDLENBQUMsQ0FBQztRQUVILEVBQUUsQ0FBQyxxREFBcUQsRUFBRSxHQUFHLEVBQUU7WUFDN0QsTUFBTSxPQUFPLEdBQUcsSUFBSSxnQ0FBcUIsQ0FBQyxtQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRXpELGdEQUFnRDtZQUNoRCxNQUFNLGVBQWUsR0FBRyxrQkFBeUMsQ0FBQztZQUVsRSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUM5RixDQUFDLENBQUMsQ0FBQztRQUVILEVBQUUsQ0FBQywyQ0FBMkMsRUFBRSxHQUFHLEVBQUU7WUFDbkQsTUFBTSxPQUFPLEdBQUcsSUFBSSxnQ0FBcUIsQ0FBQyxtQkFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRXpELENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLDhCQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FDekUsNEJBQTRCLDhCQUFtQixDQUFDLE9BQU8sRUFBRSxDQUMxRCxDQUFDO1FBQ0osQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQywwQkFBMEIsRUFBRSxHQUFHLEVBQUU7UUFDeEMsRUFBRSxDQUFDLHdEQUF3RCxFQUFFLEtBQUssSUFBSSxFQUFFO1lBQ3RFLE1BQU0sT0FBTyxHQUFHLElBQUksZ0NBQXFCLENBQUMsbUJBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUV6RCxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsaUJBQWlCLENBQUMsOEJBQW1CLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDdEUsT0FBTyxDQUFDLFVBQVUsQ0FBQyxtQkFBUSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUVuRCxNQUFNLE9BQU8sR0FBRyxNQUFNLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUV0QyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyw4QkFBbUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMzRCxPQUFPLENBQUMsVUFBVSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxtQkFBUSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNwRSxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgJ3Nob3VsZCc7XG5pbXBvcnQgc2lub24gZnJvbSAnc2lub24nO1xuaW1wb3J0IHsgTWVzc2FnZVN0YW5kYXJkVHlwZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IGZpeHR1cmVzIH0gZnJvbSAnLi9maXh0dXJlcyc7XG5pbXBvcnQgeyBNZXNzYWdlQnVpbGRlckZhY3RvcnkgfSBmcm9tICcuLi8uLi8uLi9zcmMvbGliL21lc3NhZ2VzJztcbmltcG9ydCB7IEVpcDE5MU1lc3NhZ2VCdWlsZGVyIH0gZnJvbSAnLi4vLi4vLi4vc3JjL2xpYi9tZXNzYWdlcy9laXAxOTEvZWlwMTkxTWVzc2FnZUJ1aWxkZXInO1xuXG5kZXNjcmliZSgnTWVzc2FnZSBCdWlsZGVyIEZhY3RvcnknLCAoKSA9PiB7XG4gIGNvbnN0IHNhbmRib3ggPSBzaW5vbi5jcmVhdGVTYW5kYm94KCk7XG5cbiAgYWZ0ZXJFYWNoKCgpID0+IHtcbiAgICBzYW5kYm94LnJlc3RvcmUoKTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ2dldE1lc3NhZ2VCdWlsZGVyJywgKCkgPT4ge1xuICAgIGl0KCdzaG91bGQgcmV0dXJuIHRoZSBjb3JyZWN0IGJ1aWxkZXIgZm9yIEVJUDE5MSBtZXNzYWdlIHR5cGUnLCAoKSA9PiB7XG4gICAgICBjb25zdCBmYWN0b3J5ID0gbmV3IE1lc3NhZ2VCdWlsZGVyRmFjdG9yeShmaXh0dXJlcy5jb2luKTtcblxuICAgICAgY29uc3QgYnVpbGRlciA9IGZhY3RvcnkuZ2V0TWVzc2FnZUJ1aWxkZXIoTWVzc2FnZVN0YW5kYXJkVHlwZS5FSVAxOTEpO1xuXG4gICAgICBidWlsZGVyLnNob3VsZC5iZS5pbnN0YW5jZW9mKEVpcDE5MU1lc3NhZ2VCdWlsZGVyKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgdGhyb3cgYW4gZXJyb3IgZm9yIHVuc3VwcG9ydGVkIG1lc3NhZ2UgdHlwZXMnLCAoKSA9PiB7XG4gICAgICBjb25zdCBmYWN0b3J5ID0gbmV3IE1lc3NhZ2VCdWlsZGVyRmFjdG9yeShmaXh0dXJlcy5jb2luKTtcblxuICAgICAgLy8gVGVzdCB3aXRoIGFuIGludmFsaWQvdW5zdXBwb3J0ZWQgbWVzc2FnZSB0eXBlXG4gICAgICBjb25zdCB1bnN1cHBvcnRlZFR5cGUgPSAnVU5TVVBQT1JURURfVFlQRScgYXMgTWVzc2FnZVN0YW5kYXJkVHlwZTtcblxuICAgICAgKCgpID0+IGZhY3RvcnkuZ2V0TWVzc2FnZUJ1aWxkZXIodW5zdXBwb3J0ZWRUeXBlKSkuc2hvdWxkLnRocm93KC9JbnZhbGlkIG1lc3NhZ2Ugc3RhbmRhcmQvKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgdGhyb3cgZm9yIHVua25vd24gbWVzc2FnZSBzdGFuZGFyZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IGZhY3RvcnkgPSBuZXcgTWVzc2FnZUJ1aWxkZXJGYWN0b3J5KGZpeHR1cmVzLmNvaW4pO1xuXG4gICAgICAoKCkgPT4gZmFjdG9yeS5nZXRNZXNzYWdlQnVpbGRlcihNZXNzYWdlU3RhbmRhcmRUeXBlLlVOS05PV04pKS5zaG91bGQudGhyb3coXG4gICAgICAgIGBJbnZhbGlkIG1lc3NhZ2Ugc3RhbmRhcmQgJHtNZXNzYWdlU3RhbmRhcmRUeXBlLlVOS05PV059YFxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ0ludGVncmF0aW9uIHdpdGggYnVpbGRlcicsICgpID0+IHtcbiAgICBpdCgnc2hvdWxkIGNyZWF0ZSBhIGJ1aWxkZXIgdGhhdCBjYW4gYnVpbGQgYSB2YWxpZCBtZXNzYWdlJywgYXN5bmMgKCkgPT4ge1xuICAgICAgY29uc3QgZmFjdG9yeSA9IG5ldyBNZXNzYWdlQnVpbGRlckZhY3RvcnkoZml4dHVyZXMuY29pbik7XG5cbiAgICAgIGNvbnN0IGJ1aWxkZXIgPSBmYWN0b3J5LmdldE1lc3NhZ2VCdWlsZGVyKE1lc3NhZ2VTdGFuZGFyZFR5cGUuRUlQMTkxKTtcbiAgICAgIGJ1aWxkZXIuc2V0UGF5bG9hZChmaXh0dXJlcy5tZXNzYWdlcy52YWxpZE1lc3NhZ2UpO1xuXG4gICAgICBjb25zdCBtZXNzYWdlID0gYXdhaXQgYnVpbGRlci5idWlsZCgpO1xuXG4gICAgICBtZXNzYWdlLmdldFR5cGUoKS5zaG91bGQuZXF1YWwoTWVzc2FnZVN0YW5kYXJkVHlwZS5FSVAxOTEpO1xuICAgICAgbWVzc2FnZS5nZXRQYXlsb2FkKCkuc2hvdWxkLmVxdWFsKGZpeHR1cmVzLm1lc3NhZ2VzLnZhbGlkTWVzc2FnZSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.d.ts","sourceRoot":"","sources":["../../../test/unit/token.ts"],"names":[],"mappings":"AAGA,wBAAgB,0BAA0B,CACxC,gBAAgB,KAAA,EAChB,QAAQ,EAAE,MAAM,EAChB,gBAAgB,EAAE,MAAM,EACxB,QAAQ,EAAE,GAAG,QAiCd"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runTokenTestInitialization = runTokenTestInitialization;
|
|
4
|
+
const sdk_test_1 = require("@bitgo-beta/sdk-test");
|
|
5
|
+
const sdk_api_1 = require("@bitgo-beta/sdk-api");
|
|
6
|
+
function runTokenTestInitialization(currentCoinToken, coinName, tokenNetworkName, testData) {
|
|
7
|
+
describe(`${coinName} Token:`, () => {
|
|
8
|
+
let bitgo;
|
|
9
|
+
let tokenCoin;
|
|
10
|
+
const coin = testData.COIN;
|
|
11
|
+
const tokenName = testData.NETWORK_TOKEN_IDENTIFIER;
|
|
12
|
+
before(function () {
|
|
13
|
+
bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
|
|
14
|
+
currentCoinToken.createTokenConstructors().forEach(({ name, coinConstructor }) => {
|
|
15
|
+
bitgo.safeRegister(name, coinConstructor);
|
|
16
|
+
});
|
|
17
|
+
bitgo.initializeTestVars();
|
|
18
|
+
tokenCoin = bitgo.coin(tokenName);
|
|
19
|
+
});
|
|
20
|
+
it('should return constants', () => {
|
|
21
|
+
tokenCoin.getChain().should.equal(tokenName);
|
|
22
|
+
tokenCoin.getBaseChain().should.equal(coin);
|
|
23
|
+
tokenCoin.getFullName().should.equal(`${coinName} Token`);
|
|
24
|
+
tokenCoin.getBaseFactor().should.equal(1e18);
|
|
25
|
+
tokenCoin.type.should.equal(tokenName);
|
|
26
|
+
tokenCoin.name.should.equal(tokenNetworkName);
|
|
27
|
+
tokenCoin.coin.should.equal(coin);
|
|
28
|
+
tokenCoin.network.should.equal('Testnet');
|
|
29
|
+
tokenCoin.decimalPlaces.should.equal(18);
|
|
30
|
+
});
|
|
31
|
+
it('should return same token by contract address', () => {
|
|
32
|
+
const tokencoinBycontractAddress = bitgo.coin(tokenCoin.tokenContractAddress);
|
|
33
|
+
tokenCoin.should.deepEqual(tokencoinBycontractAddress);
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi90ZXN0L3VuaXQvdG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFHQSxnRUFxQ0M7QUF4Q0QsbURBQStEO0FBQy9ELGlEQUErQztBQUUvQyxTQUFnQiwwQkFBMEIsQ0FDeEMsZ0JBQWdCLEVBQ2hCLFFBQWdCLEVBQ2hCLGdCQUF3QixFQUN4QixRQUFhO0lBRWIsUUFBUSxDQUFDLEdBQUcsUUFBUSxTQUFTLEVBQUUsR0FBRyxFQUFFO1FBQ2xDLElBQUksS0FBbUIsQ0FBQztRQUN4QixJQUFJLFNBQVMsQ0FBQztRQUNkLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDM0IsTUFBTSxTQUFTLEdBQUcsUUFBUSxDQUFDLHdCQUF3QixDQUFDO1FBQ3BELE1BQU0sQ0FBQztZQUNMLEtBQUssR0FBRyxvQkFBUyxDQUFDLFFBQVEsQ0FBQyxrQkFBUSxFQUFFLEVBQUUsR0FBRyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7WUFDdEQsZ0JBQWdCLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxFQUFFO2dCQUMvRSxLQUFLLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQztZQUM1QyxDQUFDLENBQUMsQ0FBQztZQUNILEtBQUssQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQzNCLFNBQVMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO1FBRUgsRUFBRSxDQUFDLHlCQUF5QixFQUFFLEdBQUcsRUFBRTtZQUNqQyxTQUFTLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUM3QyxTQUFTLENBQUMsWUFBWSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM1QyxTQUFTLENBQUMsV0FBVyxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLFFBQVEsUUFBUSxDQUFDLENBQUM7WUFDMUQsU0FBUyxDQUFDLGFBQWEsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDN0MsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3ZDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQzlDLFNBQVMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsQyxTQUFTLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDMUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzNDLENBQUMsQ0FBQyxDQUFDO1FBRUgsRUFBRSxDQUFDLDhDQUE4QyxFQUFFLEdBQUcsRUFBRTtZQUN0RCxNQUFNLDBCQUEwQixHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLG9CQUFvQixDQUFDLENBQUM7WUFDOUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUN6RCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlc3RCaXRHbywgVGVzdEJpdEdvQVBJIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLXRlc3QnO1xuaW1wb3J0IHsgQml0R29BUEkgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstYXBpJztcblxuZXhwb3J0IGZ1bmN0aW9uIHJ1blRva2VuVGVzdEluaXRpYWxpemF0aW9uKFxuICBjdXJyZW50Q29pblRva2VuLFxuICBjb2luTmFtZTogc3RyaW5nLFxuICB0b2tlbk5ldHdvcmtOYW1lOiBzdHJpbmcsXG4gIHRlc3REYXRhOiBhbnlcbikge1xuICBkZXNjcmliZShgJHtjb2luTmFtZX0gVG9rZW46YCwgKCkgPT4ge1xuICAgIGxldCBiaXRnbzogVGVzdEJpdEdvQVBJO1xuICAgIGxldCB0b2tlbkNvaW47XG4gICAgY29uc3QgY29pbiA9IHRlc3REYXRhLkNPSU47XG4gICAgY29uc3QgdG9rZW5OYW1lID0gdGVzdERhdGEuTkVUV09SS19UT0tFTl9JREVOVElGSUVSO1xuICAgIGJlZm9yZShmdW5jdGlvbiAoKSB7XG4gICAgICBiaXRnbyA9IFRlc3RCaXRHby5kZWNvcmF0ZShCaXRHb0FQSSwgeyBlbnY6ICd0ZXN0JyB9KTtcbiAgICAgIGN1cnJlbnRDb2luVG9rZW4uY3JlYXRlVG9rZW5Db25zdHJ1Y3RvcnMoKS5mb3JFYWNoKCh7IG5hbWUsIGNvaW5Db25zdHJ1Y3RvciB9KSA9PiB7XG4gICAgICAgIGJpdGdvLnNhZmVSZWdpc3RlcihuYW1lLCBjb2luQ29uc3RydWN0b3IpO1xuICAgICAgfSk7XG4gICAgICBiaXRnby5pbml0aWFsaXplVGVzdFZhcnMoKTtcbiAgICAgIHRva2VuQ29pbiA9IGJpdGdvLmNvaW4odG9rZW5OYW1lKTtcbiAgICB9KTtcblxuICAgIGl0KCdzaG91bGQgcmV0dXJuIGNvbnN0YW50cycsICgpID0+IHtcbiAgICAgIHRva2VuQ29pbi5nZXRDaGFpbigpLnNob3VsZC5lcXVhbCh0b2tlbk5hbWUpO1xuICAgICAgdG9rZW5Db2luLmdldEJhc2VDaGFpbigpLnNob3VsZC5lcXVhbChjb2luKTtcbiAgICAgIHRva2VuQ29pbi5nZXRGdWxsTmFtZSgpLnNob3VsZC5lcXVhbChgJHtjb2luTmFtZX0gVG9rZW5gKTtcbiAgICAgIHRva2VuQ29pbi5nZXRCYXNlRmFjdG9yKCkuc2hvdWxkLmVxdWFsKDFlMTgpO1xuICAgICAgdG9rZW5Db2luLnR5cGUuc2hvdWxkLmVxdWFsKHRva2VuTmFtZSk7XG4gICAgICB0b2tlbkNvaW4ubmFtZS5zaG91bGQuZXF1YWwodG9rZW5OZXR3b3JrTmFtZSk7XG4gICAgICB0b2tlbkNvaW4uY29pbi5zaG91bGQuZXF1YWwoY29pbik7XG4gICAgICB0b2tlbkNvaW4ubmV0d29yay5zaG91bGQuZXF1YWwoJ1Rlc3RuZXQnKTtcbiAgICAgIHRva2VuQ29pbi5kZWNpbWFsUGxhY2VzLnNob3VsZC5lcXVhbCgxOCk7XG4gICAgfSk7XG5cbiAgICBpdCgnc2hvdWxkIHJldHVybiBzYW1lIHRva2VuIGJ5IGNvbnRyYWN0IGFkZHJlc3MnLCAoKSA9PiB7XG4gICAgICBjb25zdCB0b2tlbmNvaW5CeWNvbnRyYWN0QWRkcmVzcyA9IGJpdGdvLmNvaW4odG9rZW5Db2luLnRva2VuQ29udHJhY3RBZGRyZXNzKTtcbiAgICAgIHRva2VuQ29pbi5zaG91bGQuZGVlcEVxdWFsKHRva2VuY29pbkJ5Y29udHJhY3RBZGRyZXNzKTtcbiAgICB9KTtcbiAgfSk7XG59XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../test/unit/transaction.ts"],"names":[],"mappings":"AAGA,OAAO,MAAM,MAAM,oBAAoB,CAAC;AAExC,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,QAuDlF"}
|