@bitgo-beta/sdk-coin-iota 1.0.1-beta.324 → 1.0.1-beta.325

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.
Files changed (42) hide show
  1. package/dist/src/iota.d.ts +123 -27
  2. package/dist/src/iota.d.ts.map +1 -1
  3. package/dist/src/iota.js +217 -103
  4. package/dist/src/lib/constants.d.ts +50 -1
  5. package/dist/src/lib/constants.d.ts.map +1 -1
  6. package/dist/src/lib/constants.js +68 -4
  7. package/dist/src/lib/iface.d.ts +141 -1
  8. package/dist/src/lib/iface.d.ts.map +1 -1
  9. package/dist/src/lib/iface.js +1 -1
  10. package/dist/src/lib/keyPair.d.ts +100 -6
  11. package/dist/src/lib/keyPair.d.ts.map +1 -1
  12. package/dist/src/lib/keyPair.js +103 -10
  13. package/dist/src/lib/transaction.d.ts +117 -14
  14. package/dist/src/lib/transaction.d.ts.map +1 -1
  15. package/dist/src/lib/transaction.js +190 -67
  16. package/dist/src/lib/transactionBuilder.d.ts +73 -34
  17. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  18. package/dist/src/lib/transactionBuilder.js +90 -45
  19. package/dist/src/lib/transactionBuilderFactory.d.ts +89 -6
  20. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  21. package/dist/src/lib/transactionBuilderFactory.js +103 -16
  22. package/dist/src/lib/transferBuilder.d.ts +43 -0
  23. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  24. package/dist/src/lib/transferBuilder.js +50 -5
  25. package/dist/src/lib/transferTransaction.d.ts +93 -2
  26. package/dist/src/lib/transferTransaction.d.ts.map +1 -1
  27. package/dist/src/lib/transferTransaction.js +180 -51
  28. package/dist/src/lib/utils.d.ts +107 -8
  29. package/dist/src/lib/utils.d.ts.map +1 -1
  30. package/dist/src/lib/utils.js +134 -23
  31. package/dist/test/unit/helpers/testHelpers.d.ts +57 -0
  32. package/dist/test/unit/helpers/testHelpers.d.ts.map +1 -0
  33. package/dist/test/unit/helpers/testHelpers.js +176 -0
  34. package/dist/test/unit/iota.js +47 -152
  35. package/dist/test/unit/keyPair.js +34 -61
  36. package/dist/test/unit/transactionBuilder/transactionBuilder.js +137 -255
  37. package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +43 -108
  38. package/dist/test/unit/transactionBuilder/transferBuilder.js +296 -762
  39. package/dist/test/unit/transferTransaction.js +106 -353
  40. package/dist/test/unit/utils.js +171 -197
  41. package/dist/tsconfig.tsbuildinfo +1 -1
  42. package/package.json +7 -7
@@ -32,104 +32,77 @@ describe('Iota KeyPair', function () {
32
32
  bitgo.safeRegister('tiota', src_1.Iota.createInstance);
33
33
  basecoin = bitgo.coin('tiota');
34
34
  });
35
- describe('should create a valid KeyPair', () => {
36
- it('from an empty value', async () => {
35
+ describe('KeyPair Creation', () => {
36
+ it('should create keypair with public and private keys from empty value', async () => {
37
37
  const keyPair = new src_1.KeyPair();
38
- should_1.default.exists(keyPair.getKeys().prv);
39
- should_1.default.exists(keyPair.getKeys().pub);
40
- const address = await utils_1.default.getAddressFromPublicKey(keyPair.getKeys().pub);
41
- console.log('address:', address);
42
- should_1.default.exists(address);
38
+ const keys = keyPair.getKeys();
39
+ should_1.default.exist(keys.prv);
40
+ should_1.default.exist(keys.pub);
41
+ const address = await utils_1.default.getAddressFromPublicKey(keys.pub);
42
+ should_1.default.exist(address);
43
43
  });
44
- });
45
- describe('Keypair from derived Public Key', () => {
46
- it('should create keypair with just derived public key', () => {
44
+ it('should create keypair from derived public key', () => {
47
45
  const keyPair = new src_1.KeyPair({ pub: rootPublicKey });
48
46
  keyPair.getKeys().pub.should.equal(rootPublicKey);
49
- });
50
- it('should derived ed25519 public key should be valid', () => {
51
47
  utils_1.default.isValidPublicKey(rootPublicKey).should.be.true();
52
48
  });
53
- });
54
- describe('Keypair from random seed', () => {
55
- it('should generate a keypair from random seed', function () {
49
+ it('should create keypair from random seed', () => {
56
50
  const keyPair = basecoin.generateKeyPair();
57
51
  keyPair.should.have.property('pub');
58
52
  keyPair.should.have.property('prv');
59
53
  basecoin.isValidPub(keyPair.pub).should.equal(true);
60
54
  });
61
- });
62
- describe('should fail to create a KeyPair', function () {
63
- it('from an invalid public key', () => {
64
- const source = {
65
- pub: '01D63D',
66
- };
67
- assert_1.default.throws(() => new src_1.KeyPair(source));
68
- });
69
- it('from an invalid public key with 0x prefix', () => {
70
- const source = {
71
- pub: '0x' + 'a'.repeat(64),
72
- };
73
- assert_1.default.throws(() => new src_1.KeyPair(source));
74
- });
75
- it('from a too short public key', () => {
76
- const source = {
77
- pub: 'abc123',
78
- };
79
- assert_1.default.throws(() => new src_1.KeyPair(source));
80
- });
81
- it('from a too long public key', () => {
82
- const source = {
83
- pub: 'a'.repeat(128),
84
- };
85
- assert_1.default.throws(() => new src_1.KeyPair(source));
86
- });
87
- });
88
- describe('KeyPair operations', () => {
89
- it('should get keys from keypair', () => {
55
+ it('should create keypair without private key', () => {
90
56
  const keyPair = new src_1.KeyPair({ pub: rootPublicKey });
91
57
  const keys = keyPair.getKeys();
92
58
  keys.should.have.property('pub');
93
59
  keys.pub.should.equal(rootPublicKey);
60
+ should_1.default.not.exist(keys.prv);
61
+ });
62
+ const invalidPublicKeys = [
63
+ { pub: '01D63D', description: 'invalid format' },
64
+ { pub: '0x' + 'a'.repeat(64), description: '0x prefix' },
65
+ { pub: 'abc123', description: 'too short' },
66
+ { pub: 'a'.repeat(128), description: 'too long' },
67
+ ];
68
+ invalidPublicKeys.forEach(({ pub, description }) => {
69
+ it(`should reject public key with ${description}`, () => {
70
+ assert_1.default.throws(() => new src_1.KeyPair({ pub }));
71
+ });
94
72
  });
73
+ });
74
+ describe('KeyPair Operations', () => {
95
75
  it('should generate random keypair each time', () => {
96
76
  const keyPair1 = basecoin.generateKeyPair();
97
77
  const keyPair2 = basecoin.generateKeyPair();
98
78
  keyPair1.pub.should.not.equal(keyPair2.pub);
99
79
  keyPair1.prv.should.not.equal(keyPair2.prv);
100
80
  });
101
- it('should create keypair without private key', () => {
102
- const keyPair = new src_1.KeyPair({ pub: rootPublicKey });
103
- const keys = keyPair.getKeys();
104
- keys.should.have.property('pub');
105
- keys.pub.should.equal(rootPublicKey);
106
- should_1.default.not.exist(keys.prv);
107
- });
108
81
  it('should validate generated public keys', () => {
109
82
  const keyPair = basecoin.generateKeyPair();
110
83
  basecoin.isValidPub(keyPair.pub).should.equal(true);
111
84
  utils_1.default.isValidPublicKey(keyPair.pub).should.be.true();
112
85
  });
113
86
  });
114
- describe('Address derivation', () => {
115
- it('should derive address from public key', async () => {
87
+ describe('Address Derivation', () => {
88
+ it('should derive valid address from public key', () => {
116
89
  const keyPair = new src_1.KeyPair({ pub: rootPublicKey });
117
- const address = await utils_1.default.getAddressFromPublicKey(keyPair.getKeys().pub);
90
+ const address = keyPair.getAddress();
118
91
  should_1.default.exist(address);
119
92
  utils_1.default.isValidAddress(address).should.be.true();
120
93
  });
121
- it('should derive same address from same public key', async () => {
122
- const address1 = await utils_1.default.getAddressFromPublicKey(rootPublicKey);
123
- const address2 = await utils_1.default.getAddressFromPublicKey(rootPublicKey);
94
+ it('should derive same address from same public key', () => {
95
+ const address1 = utils_1.default.getAddressFromPublicKey(rootPublicKey);
96
+ const address2 = utils_1.default.getAddressFromPublicKey(rootPublicKey);
124
97
  address1.should.equal(address2);
125
98
  });
126
- it('should derive different addresses from different public keys', async () => {
99
+ it('should derive different addresses from different public keys', () => {
127
100
  const keyPair1 = basecoin.generateKeyPair();
128
101
  const keyPair2 = basecoin.generateKeyPair();
129
- const address1 = await utils_1.default.getAddressFromPublicKey(keyPair1.pub);
130
- const address2 = await utils_1.default.getAddressFromPublicKey(keyPair2.pub);
102
+ const address1 = utils_1.default.getAddressFromPublicKey(keyPair1.pub);
103
+ const address2 = utils_1.default.getAddressFromPublicKey(keyPair2.pub);
131
104
  address1.should.not.equal(address2);
132
105
  });
133
106
  });
134
107
  });
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { KeyPair, Iota } from '../../src';\nimport utils from '../../src/lib/utils';\nimport should from 'should';\nimport { Eddsa } from '@bitgo-beta/sdk-core';\nimport { Ed25519Bip32HdTree, HDTree } from '@bitgo-beta/sdk-lib-mpc';\nimport { TestBitGo, TestBitGoAPI } from '@bitgo-beta/sdk-test';\nimport { BitGoAPI } from '@bitgo-beta/sdk-api';\n\ndescribe('Iota KeyPair', function () {\n  let rootKeychain;\n  let rootPublicKey;\n  let MPC: Eddsa;\n  let hdTree: HDTree;\n  let bitgo: TestBitGoAPI;\n  let basecoin;\n\n  before(async () => {\n    hdTree = await Ed25519Bip32HdTree.initialize();\n    MPC = await Eddsa.initialize(hdTree);\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n\n    const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;\n    rootKeychain = MPC.deriveUnhardened(commonKeychain, 'm/0');\n    rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'mock' });\n    bitgo.safeRegister('tiota', Iota.createInstance);\n    basecoin = bitgo.coin('tiota');\n  });\n\n  describe('should create a valid KeyPair', () => {\n    it('from an empty value', async () => {\n      const keyPair = new KeyPair();\n      should.exists(keyPair.getKeys().prv);\n      should.exists(keyPair.getKeys().pub);\n      const address = await utils.getAddressFromPublicKey(keyPair.getKeys().pub);\n      console.log('address:', address);\n      should.exists(address);\n    });\n  });\n\n  describe('Keypair from derived Public Key', () => {\n    it('should create keypair with just derived public key', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      keyPair.getKeys().pub.should.equal(rootPublicKey);\n    });\n\n    it('should derived ed25519 public key should be valid', () => {\n      utils.isValidPublicKey(rootPublicKey).should.be.true();\n    });\n  });\n\n  describe('Keypair from random seed', () => {\n    it('should generate a keypair from random seed', function () {\n      const keyPair = basecoin.generateKeyPair();\n      keyPair.should.have.property('pub');\n      keyPair.should.have.property('prv');\n      basecoin.isValidPub(keyPair.pub).should.equal(true);\n    });\n  });\n\n  describe('should fail to create a KeyPair', function () {\n    it('from an invalid public key', () => {\n      const source = {\n        pub: '01D63D',\n      };\n\n      assert.throws(() => new KeyPair(source));\n    });\n\n    it('from an invalid public key with 0x prefix', () => {\n      const source = {\n        pub: '0x' + 'a'.repeat(64),\n      };\n\n      assert.throws(() => new KeyPair(source));\n    });\n\n    it('from a too short public key', () => {\n      const source = {\n        pub: 'abc123',\n      };\n\n      assert.throws(() => new KeyPair(source));\n    });\n\n    it('from a too long public key', () => {\n      const source = {\n        pub: 'a'.repeat(128),\n      };\n\n      assert.throws(() => new KeyPair(source));\n    });\n  });\n\n  describe('KeyPair operations', () => {\n    it('should get keys from keypair', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      const keys = keyPair.getKeys();\n\n      keys.should.have.property('pub');\n      keys.pub.should.equal(rootPublicKey);\n    });\n\n    it('should generate random keypair each time', () => {\n      const keyPair1 = basecoin.generateKeyPair();\n      const keyPair2 = basecoin.generateKeyPair();\n\n      keyPair1.pub.should.not.equal(keyPair2.pub);\n      keyPair1.prv.should.not.equal(keyPair2.prv);\n    });\n\n    it('should create keypair without private key', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      const keys = keyPair.getKeys();\n\n      keys.should.have.property('pub');\n      keys.pub.should.equal(rootPublicKey);\n      should.not.exist(keys.prv);\n    });\n\n    it('should validate generated public keys', () => {\n      const keyPair = basecoin.generateKeyPair();\n      basecoin.isValidPub(keyPair.pub).should.equal(true);\n      utils.isValidPublicKey(keyPair.pub).should.be.true();\n    });\n  });\n\n  describe('Address derivation', () => {\n    it('should derive address from public key', async () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      const address = await utils.getAddressFromPublicKey(keyPair.getKeys().pub);\n\n      should.exist(address);\n      utils.isValidAddress(address).should.be.true();\n    });\n\n    it('should derive same address from same public key', async () => {\n      const address1 = await utils.getAddressFromPublicKey(rootPublicKey);\n      const address2 = await utils.getAddressFromPublicKey(rootPublicKey);\n\n      address1.should.equal(address2);\n    });\n\n    it('should derive different addresses from different public keys', async () => {\n      const keyPair1 = basecoin.generateKeyPair();\n      const keyPair2 = basecoin.generateKeyPair();\n\n      const address1 = await utils.getAddressFromPublicKey(keyPair1.pub);\n      const address2 = await utils.getAddressFromPublicKey(keyPair2.pub);\n\n      address1.should.not.equal(address2);\n    });\n  });\n});\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":";;;;;AAAA,oDAA4B;AAC5B,mCAA0C;AAC1C,gEAAwC;AACxC,oDAA4B;AAC5B,mDAA6C;AAC7C,yDAAqE;AACrE,mDAA+D;AAC/D,iDAA+C;AAE/C,QAAQ,CAAC,cAAc,EAAE;IACvB,IAAI,YAAY,CAAC;IACjB,IAAI,aAAa,CAAC;IAClB,IAAI,GAAU,CAAC;IACf,IAAI,MAAc,CAAC;IACnB,IAAI,KAAmB,CAAC;IACxB,IAAI,QAAQ,CAAC;IAEb,MAAM,CAAC,KAAK,IAAI,EAAE;QAChB,MAAM,GAAG,MAAM,gCAAkB,CAAC,UAAU,EAAE,CAAC;QAC/C,GAAG,GAAG,MAAM,gBAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAEhC,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAEzE,MAAM,cAAc,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;QACvE,YAAY,GAAG,GAAG,CAAC,gBAAgB,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAC3D,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC9E,KAAK,GAAG,oBAAS,CAAC,QAAQ,CAAC,kBAAQ,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC;QACtD,KAAK,CAAC,YAAY,CAAC,OAAO,EAAE,UAAI,CAAC,cAAc,CAAC,CAAC;QACjD,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,qEAAqE,EAAE,KAAK,IAAI,EAAE;YACnF,MAAM,OAAO,GAAG,IAAI,aAAO,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAE/B,gBAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACvB,gBAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAEvB,MAAM,OAAO,GAAG,MAAM,eAAK,CAAC,uBAAuB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9D,gBAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACvD,MAAM,OAAO,GAAG,IAAI,aAAO,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,CAAC,CAAC;YACpD,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YAClD,eAAK,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;QACzD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wCAAwC,EAAE,GAAG,EAAE;YAChD,MAAM,OAAO,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAC3C,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACpC,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;YACnD,MAAM,OAAO,GAAG,IAAI,aAAO,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,CAAC,CAAC;YACpD,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAE/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;YACrC,gBAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG;YACxB,EAAE,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,gBAAgB,EAAE;YAChD,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE;YACxD,EAAE,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE;YAC3C,EAAE,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE;SAClD,CAAC;QAEF,iBAAiB,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,EAAE,EAAE;YACjD,EAAE,CAAC,iCAAiC,WAAW,EAAE,EAAE,GAAG,EAAE;gBACtD,gBAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,aAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;YAC5C,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YAClD,MAAM,QAAQ,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAC5C,MAAM,QAAQ,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAE5C,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC5C,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,OAAO,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAC3C,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACpD,eAAK,CAAC,gBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;QACvD,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;QAClC,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACrD,MAAM,OAAO,GAAG,IAAI,aAAO,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,CAAC,CAAC;YACpD,MAAM,OAAO,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;YAErC,gBAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACtB,eAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;YACzD,MAAM,QAAQ,GAAG,eAAK,CAAC,uBAAuB,CAAC,aAAa,CAAC,CAAC;YAC9D,MAAM,QAAQ,GAAG,eAAK,CAAC,uBAAuB,CAAC,aAAa,CAAC,CAAC;YAE9D,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8DAA8D,EAAE,GAAG,EAAE;YACtE,MAAM,QAAQ,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAC5C,MAAM,QAAQ,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;YAE5C,MAAM,QAAQ,GAAG,eAAK,CAAC,uBAAuB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC7D,MAAM,QAAQ,GAAG,eAAK,CAAC,uBAAuB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAE7D,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import assert from 'assert';\nimport { KeyPair, Iota } from '../../src';\nimport utils from '../../src/lib/utils';\nimport should from 'should';\nimport { Eddsa } from '@bitgo-beta/sdk-core';\nimport { Ed25519Bip32HdTree, HDTree } from '@bitgo-beta/sdk-lib-mpc';\nimport { TestBitGo, TestBitGoAPI } from '@bitgo-beta/sdk-test';\nimport { BitGoAPI } from '@bitgo-beta/sdk-api';\n\ndescribe('Iota KeyPair', function () {\n  let rootKeychain;\n  let rootPublicKey;\n  let MPC: Eddsa;\n  let hdTree: HDTree;\n  let bitgo: TestBitGoAPI;\n  let basecoin;\n\n  before(async () => {\n    hdTree = await Ed25519Bip32HdTree.initialize();\n    MPC = await Eddsa.initialize(hdTree);\n    const A = MPC.keyShare(1, 2, 3);\n    const B = MPC.keyShare(2, 2, 3);\n    const C = MPC.keyShare(3, 2, 3);\n\n    const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n\n    const commonKeychain = A_combine.pShare.y + A_combine.pShare.chaincode;\n    rootKeychain = MPC.deriveUnhardened(commonKeychain, 'm/0');\n    rootPublicKey = Buffer.from(rootKeychain, 'hex').slice(0, 32).toString('hex');\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'mock' });\n    bitgo.safeRegister('tiota', Iota.createInstance);\n    basecoin = bitgo.coin('tiota');\n  });\n\n  describe('KeyPair Creation', () => {\n    it('should create keypair with public and private keys from empty value', async () => {\n      const keyPair = new KeyPair();\n      const keys = keyPair.getKeys();\n\n      should.exist(keys.prv);\n      should.exist(keys.pub);\n\n      const address = await utils.getAddressFromPublicKey(keys.pub);\n      should.exist(address);\n    });\n\n    it('should create keypair from derived public key', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      keyPair.getKeys().pub.should.equal(rootPublicKey);\n      utils.isValidPublicKey(rootPublicKey).should.be.true();\n    });\n\n    it('should create keypair from random seed', () => {\n      const keyPair = basecoin.generateKeyPair();\n      keyPair.should.have.property('pub');\n      keyPair.should.have.property('prv');\n      basecoin.isValidPub(keyPair.pub).should.equal(true);\n    });\n\n    it('should create keypair without private key', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      const keys = keyPair.getKeys();\n\n      keys.should.have.property('pub');\n      keys.pub.should.equal(rootPublicKey);\n      should.not.exist(keys.prv);\n    });\n\n    const invalidPublicKeys = [\n      { pub: '01D63D', description: 'invalid format' },\n      { pub: '0x' + 'a'.repeat(64), description: '0x prefix' },\n      { pub: 'abc123', description: 'too short' },\n      { pub: 'a'.repeat(128), description: 'too long' },\n    ];\n\n    invalidPublicKeys.forEach(({ pub, description }) => {\n      it(`should reject public key with ${description}`, () => {\n        assert.throws(() => new KeyPair({ pub }));\n      });\n    });\n  });\n\n  describe('KeyPair Operations', () => {\n    it('should generate random keypair each time', () => {\n      const keyPair1 = basecoin.generateKeyPair();\n      const keyPair2 = basecoin.generateKeyPair();\n\n      keyPair1.pub.should.not.equal(keyPair2.pub);\n      keyPair1.prv.should.not.equal(keyPair2.prv);\n    });\n\n    it('should validate generated public keys', () => {\n      const keyPair = basecoin.generateKeyPair();\n      basecoin.isValidPub(keyPair.pub).should.equal(true);\n      utils.isValidPublicKey(keyPair.pub).should.be.true();\n    });\n  });\n\n  describe('Address Derivation', () => {\n    it('should derive valid address from public key', () => {\n      const keyPair = new KeyPair({ pub: rootPublicKey });\n      const address = keyPair.getAddress();\n\n      should.exist(address);\n      utils.isValidAddress(address).should.be.true();\n    });\n\n    it('should derive same address from same public key', () => {\n      const address1 = utils.getAddressFromPublicKey(rootPublicKey);\n      const address2 = utils.getAddressFromPublicKey(rootPublicKey);\n\n      address1.should.equal(address2);\n    });\n\n    it('should derive different addresses from different public keys', () => {\n      const keyPair1 = basecoin.generateKeyPair();\n      const keyPair2 = basecoin.generateKeyPair();\n\n      const address1 = utils.getAddressFromPublicKey(keyPair1.pub);\n      const address2 = utils.getAddressFromPublicKey(keyPair2.pub);\n\n      address1.should.not.equal(address2);\n    });\n  });\n});\n"]}