@bitgo/sdk-coin-xtz 2.10.6 → 2.10.7

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.
@@ -1 +1 @@
1
- {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,eAAe,EAIhB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAIxD,OAAO,EAAE,gBAAgB,EAAiB,iBAAiB,EAA2B,MAAM,SAAS,CAAC;AACtG,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC;;GAEG;AACH,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,kBAAkB,CAAC,CAAoB;IAC/C,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,OAAO,CAAW;IAE1B;;;;OAIG;gBACS,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK5C;;;;OAIG;IACG,6BAA6B,CAAC,qBAAqB,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBjF;;;;;OAKG;IACG,yBAAyB,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA0C5G;;;;;;OAMG;YACW,yBAAyB;IAwBvC;;;;OAIG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;OAIG;IACH,OAAO,CAAC,yBAAyB;IA6BjC;;;;;OAKG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB3C;;;;;;OAMG;IACG,oBAAoB,CAAC,UAAU,EAAE,gBAAgB,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxF,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAK9B,kBAAkB;IAClB,MAAM,IAAI,iBAAiB;IAO3B,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAO3B;;;;OAIG;IACH,IAAI,MAAM,IAAI,MAAM,CAKnB;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED;;;;OAIG;IACH,IAAI,iBAAiB,IAAI,MAAM,GAAG,SAAS,CAE1C;IAED;;;;OAIG;IACH,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,aAAa,SAAI,GAAG,gBAAgB,EAAE;IAO5D;;;;;OAKG;IACH,2BAA2B,IAAI;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE;CAW5D"}
1
+ {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,eAAe,EAA4C,MAAM,iBAAiB,CAAC;AACrG,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAIxD,OAAO,EAAE,gBAAgB,EAAiB,iBAAiB,EAA2B,MAAM,SAAS,CAAC;AACtG,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAoCpC;;GAEG;AACH,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,kBAAkB,CAAC,CAAoB;IAC/C,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,OAAO,CAAW;IAE1B;;;;OAIG;gBACS,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK5C;;;;OAIG;IACG,6BAA6B,CAAC,qBAAqB,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAcjF;;;;;OAKG;IACG,yBAAyB,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA0C5G;;;;;;OAMG;YACW,yBAAyB;IAwBvC;;;;OAIG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;OAIG;IACH,OAAO,CAAC,yBAAyB;IA6BjC;;;;;OAKG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB3C;;;;;;OAMG;IACG,oBAAoB,CAAC,UAAU,EAAE,gBAAgB,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxF,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAK9B,kBAAkB;IAClB,MAAM,IAAI,iBAAiB;IAO3B,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAO3B;;;;OAIG;IACH,IAAI,MAAM,IAAI,MAAM,CAKnB;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED;;;;OAIG;IACH,IAAI,iBAAiB,IAAI,MAAM,GAAG,SAAS,CAE1C;IAED;;;;OAIG;IACH,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,aAAa,SAAI,GAAG,gBAAgB,EAAE;IAO5D;;;;;OAKG;IACH,2BAA2B,IAAI;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE;CAW5D"}
@@ -43,6 +43,29 @@ const rpc_1 = require("@taquito/rpc");
43
43
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
44
44
  const multisigUtils_1 = require("./multisigUtils");
45
45
  const Utils = __importStar(require("./utils"));
46
+ const SIGNATURE_HEX_LENGTH = 128;
47
+ async function tryParseSigned(serialized) {
48
+ if (serialized.length <= SIGNATURE_HEX_LENGTH) {
49
+ return undefined;
50
+ }
51
+ // If `serialized` really is `forge(ops) || signature`, stripping the trailing 64
52
+ // bytes gives the exact forge bytes and forge(parse(...)) reproduces them. If
53
+ // `serialized` was unsigned, stripping cuts into the operation contents: parse
54
+ // either throws or recovers a truncated parse whose forge does not match. So a
55
+ // clean round-trip is what proves the trailing bytes were a signature.
56
+ const operationBytes = serialized.slice(0, -SIGNATURE_HEX_LENGTH);
57
+ try {
58
+ const parsed = await local_forging_1.localForger.parse(operationBytes);
59
+ const roundTrip = await local_forging_1.localForger.forge(parsed);
60
+ if (roundTrip !== operationBytes) {
61
+ return undefined;
62
+ }
63
+ return { parsed, transactionId: await Utils.calculateTransactionId(serialized) };
64
+ }
65
+ catch (_) {
66
+ return undefined;
67
+ }
68
+ }
46
69
  /**
47
70
  * Tezos transaction model.
48
71
  */
@@ -63,23 +86,16 @@ class Transaction extends sdk_core_1.BaseTransaction {
63
86
  */
64
87
  async initFromSerializedTransaction(serializedTransaction) {
65
88
  this._encodedTransaction = serializedTransaction;
66
- try {
67
- const parsedTransaction = await local_forging_1.localForger.parse(serializedTransaction);
68
- await this.initFromParsedTransaction(parsedTransaction);
69
- }
70
- catch (e) {
71
- // If it throws, it is possible the serialized transaction is signed, which is not supported
72
- // by local-forging. Try extracting the last 64 bytes and parse it again.
73
- const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);
74
- const signature = serializedTransaction.slice(-128);
75
- if (Utils.isValidSignature(signature)) {
76
- throw new sdk_core_1.ParseTransactionError('Invalid transaction');
77
- }
89
+ // Only signed inputs have a transaction id (it is the hash of the signed bytes);
90
+ // unsigned inputs leave it unset and let the caller populate it after signing.
91
+ const signed = await tryParseSigned(serializedTransaction);
92
+ if (signed) {
78
93
  // TODO: encode the signature and save it in _signature
79
- const parsedTransaction = await local_forging_1.localForger.parse(unsignedSerializedTransaction);
80
- const transactionId = await Utils.calculateTransactionId(serializedTransaction);
81
- await this.initFromParsedTransaction(parsedTransaction, transactionId);
94
+ await this.initFromParsedTransaction(signed.parsed, signed.transactionId);
95
+ return;
82
96
  }
97
+ const parsed = await local_forging_1.localForger.parse(serializedTransaction);
98
+ await this.initFromParsedTransaction(parsed);
83
99
  }
84
100
  /**
85
101
  * Initialize the transaction fields based on another parsed transaction.
@@ -328,4 +344,4 @@ class Transaction extends sdk_core_1.BaseTransaction {
328
344
  }
329
345
  }
330
346
  exports.Transaction = Transaction;
331
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8CAMyB;AAEzB,0DAAqD;AACrD,sCAAsC;AACtC,gEAAqC;AAGrC,mDAMyB;AACzB,+CAAiC;AAEjC;;GAEG;AACH,MAAa,WAAY,SAAQ,0BAAe;IAS9C;;;;OAIG;IACH,YAAY,UAAgC;QAC1C,KAAK,CAAC,UAAU,CAAC,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,6BAA6B,CAAC,qBAA6B;QAC/D,IAAI,CAAC,mBAAmB,GAAG,qBAAqB,CAAC;QACjD,IAAI,CAAC;YACH,MAAM,iBAAiB,GAAG,MAAM,2BAAW,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;YACzE,MAAM,IAAI,CAAC,yBAAyB,CAAC,iBAAiB,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,4FAA4F;YAC5F,yEAAyE;YACzE,MAAM,6BAA6B,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;YAC3E,MAAM,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;YACpD,IAAI,KAAK,CAAC,gBAAgB,CAAC,SAAS,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,gCAAqB,CAAC,qBAAqB,CAAC,CAAC;YACzD,CAAC;YACD,uDAAuD;YACvD,MAAM,iBAAiB,GAAG,MAAM,2BAAW,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;YACjF,MAAM,aAAa,GAAG,MAAM,KAAK,CAAC,sBAAsB,CAAC,qBAAqB,CAAC,CAAC;YAChF,MAAM,IAAI,CAAC,yBAAyB,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,yBAAyB,CAAC,iBAAoC,EAAE,aAAsB;QAC1F,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC9B,IAAI,CAAC,mBAAmB,GAAG,MAAM,2BAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QACxE,CAAC;QACD,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,GAAG,GAAG,aAAa,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,kBAAkB,GAAG,iBAAiB,CAAC;QAC5C,IAAI,cAAc,GAAG,CAAC,CAAC;QACvB,KAAK,MAAM,SAAS,IAAI,iBAAiB,CAAC,QAAQ,EAAE,CAAC;YACnD,+DAA+D;YAC/D,IAAI,QAAQ,IAAI,SAAS,EAAE,CAAC;gBAC1B,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC,MAAM,EAAE,CAAC;oBACtD,MAAM,IAAI,kCAAuB,CAC/B,mEAAmE,IAAI,CAAC,OAAO,OAAO,SAAS,CAAC,MAAM,EAAE,CACzG,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,MAAM,CAAC;gBAClC,CAAC;YACH,CAAC;YAED,QAAQ,SAAS,CAAC,IAAI,EAAE,CAAC;gBACvB,KAAK,YAAM,CAAC,WAAW;oBACrB,MAAM,IAAI,CAAC,yBAAyB,CAAC,SAA0B,EAAE,cAAc,CAAC,CAAC;oBACjF,cAAc,EAAE,CAAC;oBACjB,MAAM;gBACR,KAAK,YAAM,CAAC,MAAM;oBAChB,IAAI,CAAC,oBAAoB,CAAC,SAAqB,CAAC,CAAC;oBACjD,MAAM;gBACR,KAAK,YAAM,CAAC,WAAW;oBACrB,IAAI,CAAC,yBAAyB,CAAC,SAA0B,CAAC,CAAC;oBAC3D,MAAM;gBACR;oBACE,MAAM,CAAC,wDAAwD;YACnE,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACK,KAAK,CAAC,yBAAyB,CAAC,SAAwB,EAAE,KAAa;QAC7E,MAAM,eAAe,GAAG,IAAA,+CAA+B,EAAC,SAAS,CAAC,CAAC;QACnE,IAAI,eAAe,CAAC,oBAAoB,EAAE,CAAC;YACzC,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,qBAAqB,CAAC;YACnD,IAAI,CAAC,qBAAqB,GAAG,eAAe,CAAC,oBAAoB,CAAC;QACpE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,oBAAoB,CAAC;YAClD,IAAI,CAAC,OAAO,GAAG,IAAA,mCAAmB,EAAC,SAAS,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,QAAQ,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACjB,yEAAyE;YACzE,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,0BAA0B,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YAChF,UAAU;YACV,KAAK,EAAE,SAAS,CAAC,OAAO;SACzB,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,OAAO,EAAE,SAAS,CAAC,MAAM;YACzB,wEAAwE;YACxE,KAAK,EAAE,IAAI,sBAAS,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE;SACvE,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACK,oBAAoB,CAAC,SAAmB;QAC9C,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,aAAa,CAAC;QAC3C,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,UAAU,CAAC;QAC/C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,OAAO,EAAE,SAAS,CAAC,MAAM;YACzB,wEAAwE;YACxE,KAAK,EAAE,SAAS,CAAC,GAAG;SACrB,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACK,yBAAyB,CAAC,SAAwB;QACxD,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC;YACzB,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,IAAI,CAAC;QACpC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,0BAAe,CAAC,aAAa,CAAC;QAC7C,CAAC;QACD,MAAM,YAAY,GAAG,IAAA,oDAAoC,EAAC,SAAS,CAAC,CAAC;QACrE,gFAAgF;QAChF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAChB,OAAO,EAAE,SAAS,CAAC,MAAM;YACzB,KAAK,EAAE,IAAI,sBAAS,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;SACtD,CAAC,CAAC;QAEH,IAAI,YAAY,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACjB,yEAAyE;gBACzE,OAAO,EAAE,YAAY,CAAC,EAAE;gBACxB,UAAU;gBACV,KAAK,EAAE,YAAY,CAAC,MAAM;aAC3B,CAAC,CAAC;YACH,8CAA8C;YAC9C,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAChB,OAAO,EAAE,YAAY,CAAC,IAAI;gBAC1B,wEAAwE;gBACxE,KAAK,EAAE,YAAY,CAAC,MAAM;aAC3B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,OAAgB;QACzB,kDAAkD;QAClD,0CAA0C;QAC1C,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,MAAM,IAAI,kCAAuB,CAAC,mBAAmB,CAAC,CAAC;QACzD,CAAC;QACD,mCAAmC;QACnC,MAAM,kBAAkB,GAAG,MAAM,2BAAW,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAE5E,MAAM,iBAAiB,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;QACxE,IAAI,CAAC,mBAAmB,GAAG,iBAAiB,CAAC,MAAM,CAAC;QAEpD,oEAAoE;QACpE,IAAI,CAAC,GAAG,GAAG,MAAM,KAAK,CAAC,sBAAsB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACxE,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAExE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,oBAAoB,CAAC,UAA8B,EAAE,KAAa;QACtE,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,MAAM,IAAI,kCAAuB,CAAC,mBAAmB,CAAC,CAAC;QACzD,CAAC;QACD,IAAA,gDAAgC,EAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAkB,EAAE,UAAU,CAAC,CAAC;QACvG,IAAI,CAAC,mBAAmB,GAAG,MAAM,2BAAW,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9E,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,GAAY;QAClB,2EAA2E;QAC3E,OAAO,IAAI,CAAC;IACd,CAAC;IAED,kBAAkB;IAClB,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,MAAM,IAAI,kCAAuB,CAAC,mBAAmB,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAED,kBAAkB;IAClB,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC9B,MAAM,IAAI,kCAAuB,CAAC,6BAA6B,CAAC,CAAC;QACnE,CAAC;QACD,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACH,IAAI,MAAM;QACR,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,kCAAuB,CAAC,6BAA6B,CAAC,CAAC;QACnE,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;OAIG;IACH,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACH,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,aAAa,GAAG,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,OAAO,IAAA,6CAA6B,EAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,aAAa,CAAkB,CAAC,CAAC;IACzG,CAAC;IAED;;;;;OAKG;IACH,2BAA2B;QACzB,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC7B,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACjE,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACtD,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;CACF;AApTD,kCAoTC","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  ParseTransactionError,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { localForger } from '@taquito/local-forging';\nimport { OpKind } from '@taquito/rpc';\nimport BigNumber from 'bignumber.js';\nimport { IndexedSignature, OriginationOp, ParsedTransaction, RevealOp, TransactionOp } from './iface';\nimport { KeyPair } from './keyPair';\nimport {\n  getMultisigTransferDataFromOperation,\n  getMultisigTransferSignatures,\n  getOriginationDataFromOperation,\n  getOwnersPublicKeys,\n  updateMultisigTransferSignatures,\n} from './multisigUtils';\nimport * as Utils from './utils';\n\n/**\n * Tezos transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  private _parsedTransaction?: ParsedTransaction; // transaction in JSON format\n  private _encodedTransaction?: string; // transaction in hex format\n  private _source: string;\n  private _delegate?: string;\n  private _forwarderDestination?: string;\n  private _publicKeyToReveal?: string;\n  private _owners: string[];\n\n  /**\n   * Public constructor.\n   *\n   * @param {Readonly<CoinConfig>} coinConfig\n   */\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._owners = [];\n  }\n\n  /**\n   * Initialize the transaction fields based on another serialized transaction.\n   *\n   * @param serializedTransaction Transaction in broadcast format.\n   */\n  async initFromSerializedTransaction(serializedTransaction: string): Promise<void> {\n    this._encodedTransaction = serializedTransaction;\n    try {\n      const parsedTransaction = await localForger.parse(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction);\n    } catch (e) {\n      // If it throws, it is possible the serialized transaction is signed, which is not supported\n      // by local-forging. Try extracting the last 64 bytes and parse it again.\n      const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);\n      const signature = serializedTransaction.slice(-128);\n      if (Utils.isValidSignature(signature)) {\n        throw new ParseTransactionError('Invalid transaction');\n      }\n      // TODO: encode the signature and save it in _signature\n      const parsedTransaction = await localForger.parse(unsignedSerializedTransaction);\n      const transactionId = await Utils.calculateTransactionId(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction, transactionId);\n    }\n  }\n\n  /**\n   * Initialize the transaction fields based on another parsed transaction.\n   *\n   * @param {ParsedTransaction} parsedTransaction A Tezos transaction object\n   * @param {string} transactionId The transaction id of the parsedTransaction if it is signed\n   */\n  async initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void> {\n    if (!this._encodedTransaction) {\n      this._encodedTransaction = await localForger.forge(parsedTransaction);\n    }\n    if (transactionId) {\n      this._id = transactionId;\n      this._inputs = [];\n      this._outputs = [];\n    } else {\n      this._id = '';\n    }\n    this._parsedTransaction = parsedTransaction;\n    let operationIndex = 0;\n    for (const operation of parsedTransaction.contents) {\n      // Narrowing: only operations with a source have a source field\n      if ('source' in operation) {\n        if (this._source && this._source !== operation.source) {\n          throw new InvalidTransactionError(\n            `Source must be the same for every operation but it changed from ${this._source} to ${operation.source}`\n          );\n        } else {\n          this._source = operation.source;\n        }\n      }\n\n      switch (operation.kind) {\n        case OpKind.ORIGINATION:\n          await this.recordOriginationOpFields(operation as OriginationOp, operationIndex);\n          operationIndex++;\n          break;\n        case OpKind.REVEAL:\n          this.recordRevealOpFields(operation as RevealOp);\n          break;\n        case OpKind.TRANSACTION:\n          this.recordTransactionOpFields(operation as TransactionOp);\n          break;\n        default:\n          break; // skip operations like attestations, endorsements, etc.\n      }\n    }\n  }\n\n  /**\n   * Record the most important fields from an origination operation.\n   *\n   * @param {Operation} operation An operation object from a Tezos transaction\n   * @param {number} index The origination operation index in the transaction. Used to calculate the\n   *      originated address\n   */\n  private async recordOriginationOpFields(operation: OriginationOp, index: number): Promise<void> {\n    const originationData = getOriginationDataFromOperation(operation);\n    if (originationData.forwarderDestination) {\n      this._type = TransactionType.AddressInitialization;\n      this._forwarderDestination = originationData.forwarderDestination;\n    } else {\n      this._type = TransactionType.WalletInitialization;\n      this._owners = getOwnersPublicKeys(operation);\n    }\n\n    this._delegate = operation.delegate;\n    this._outputs.push({\n      // Kt addresses can only be calculated for signed transactions with an id\n      address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',\n      // Balance\n      value: operation.balance,\n    });\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: new BigNumber(operation.balance).plus(operation.fee).toString(),\n    });\n  }\n\n  /**\n   * Record the most important fields from a reveal operation.\n   *\n   * @param {RevealOp} operation A reveal operation object from a Tezos transaction\n   */\n  private recordRevealOpFields(operation: RevealOp): void {\n    this._type = TransactionType.AccountUpdate;\n    this._publicKeyToReveal = operation.public_key;\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: operation.fee,\n    });\n  }\n\n  /**\n   * Record the most important fields for a Transaction operation.\n   *\n   * @param {TransactionOp} operation A transaction object from a Tezos operation\n   */\n  private recordTransactionOpFields(operation: TransactionOp): void {\n    if (operation.parameters) {\n      this._type = TransactionType.Send;\n    } else {\n      this._type = TransactionType.SingleSigSend;\n    }\n    const transferData = getMultisigTransferDataFromOperation(operation);\n    // Fees are paid by the source account, along with the amount in the transaction\n    this._inputs.push({\n      address: operation.source,\n      value: new BigNumber(transferData.fee.fee).toFixed(0),\n    });\n\n    if (transferData.coin === 'mutez') {\n      this._outputs.push({\n        // Kt addresses can only be calculated for signed transactions with an id\n        address: transferData.to,\n        // Balance\n        value: transferData.amount,\n      });\n      // The funds being transferred from the wallet\n      this._inputs.push({\n        address: transferData.from,\n        // Balance + fees + max gas + max storage are paid by the source account\n        value: transferData.amount,\n      });\n    }\n  }\n\n  /**\n   * Sign the transaction with the provided key. It does not check if the signer is allowed to sign\n   * it or not.\n   *\n   * @param {KeyPair} keyPair The key to sign the transaction with\n   */\n  async sign(keyPair: KeyPair): Promise<void> {\n    // TODO: fail if the transaction is already signed\n    // Check if there is a transaction to sign\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // Get the transaction body to sign\n    const encodedTransaction = await localForger.forge(this._parsedTransaction);\n\n    const signedTransaction = await Utils.sign(keyPair, encodedTransaction);\n    this._encodedTransaction = signedTransaction.sbytes;\n\n    // The transaction id can only be calculated for signed transactions\n    this._id = await Utils.calculateTransactionId(this._encodedTransaction);\n    await this.initFromParsedTransaction(this._parsedTransaction, this._id);\n\n    this._signatures.push(signedTransaction.sig);\n  }\n\n  /**\n   * Update the list of signatures for a multisig transaction operation.\n   *\n   * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on\n   *    in the multisig transfer\n   * @param {number} index The transfer index to add the signatures to\n   */\n  async addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void> {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    updateMultisigTransferSignatures(this._parsedTransaction.contents[index] as TransactionOp, signatures);\n    this._encodedTransaction = await localForger.forge(this._parsedTransaction);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // TODO: check the key belongs to the _source account in _parsedTransaction\n    return true;\n  }\n\n  /** @inheritdoc */\n  toJson(): ParsedTransaction {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this._parsedTransaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._encodedTransaction) {\n      throw new InvalidTransactionError('Missing encoded transaction');\n    }\n    return this._encodedTransaction;\n  }\n\n  /**\n   * Get the transaction source if it is available.\n   *\n   * @returns {string} Source of the transaction\n   */\n  get source(): string {\n    if (!this._source) {\n      throw new InvalidTransactionError('Transaction not initialized');\n    }\n    return this._source;\n  }\n\n  /**\n   * Get the transaction delegation address if it is available.\n   *\n   * @returns {string} transaction delegation address\n   */\n  get delegate(): string | undefined {\n    return this._delegate;\n  }\n\n  /**\n   * Get the public key revealed by the transaction if it exists\n   *\n   * @returns {string} public key\n   */\n  get publicKeyToReveal(): string | undefined {\n    return this._publicKeyToReveal;\n  }\n\n  /**\n   * Get the destination of an address initialization transaction if it exists\n   *\n   * @returns {string} forwarder destination\n   */\n  get forwarderDestination(): string | undefined {\n    return this._forwarderDestination;\n  }\n\n  get owners(): string[] {\n    return this._owners;\n  }\n\n  /**\n   * Get the signatures for the given multisig transfer,\n   *\n   * @param {number} transferIndex The transfer script index in the Tezos transaction\n   * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer\n   *      script\n   */\n  getTransferSignatures(transferIndex = 0): IndexedSignature[] {\n    if (!this._parsedTransaction) {\n      return [];\n    }\n    return getMultisigTransferSignatures(this._parsedTransaction.contents[transferIndex] as TransactionOp);\n  }\n\n  /**\n   * Get the list of index per tezos transaction type. This is useful to locate specific operations\n   * within the transaction and verify or sign them.\n   *\n   * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind\n   */\n  getIndexesByTransactionType(): { [kind: string]: number[] } {\n    if (!this._parsedTransaction) {\n      return {};\n    }\n    const indexes = {};\n    for (let i = 0; i < this._parsedTransaction.contents.length; i++) {\n      const kind = this._parsedTransaction.contents[i].kind;\n      indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];\n    }\n    return indexes;\n  }\n}\n"]}
347
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseKey, BaseTransaction, InvalidTransactionError, TransactionType } from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { localForger } from '@taquito/local-forging';\nimport { OpKind } from '@taquito/rpc';\nimport BigNumber from 'bignumber.js';\nimport { IndexedSignature, OriginationOp, ParsedTransaction, RevealOp, TransactionOp } from './iface';\nimport { KeyPair } from './keyPair';\nimport {\n  getMultisigTransferDataFromOperation,\n  getMultisigTransferSignatures,\n  getOriginationDataFromOperation,\n  getOwnersPublicKeys,\n  updateMultisigTransferSignatures,\n} from './multisigUtils';\nimport * as Utils from './utils';\n\nconst SIGNATURE_HEX_LENGTH = 128;\n\nasync function tryParseSigned(\n  serialized: string\n): Promise<{ parsed: ParsedTransaction; transactionId: string } | undefined> {\n  if (serialized.length <= SIGNATURE_HEX_LENGTH) {\n    return undefined;\n  }\n  // If `serialized` really is `forge(ops) || signature`, stripping the trailing 64\n  // bytes gives the exact forge bytes and forge(parse(...)) reproduces them. If\n  // `serialized` was unsigned, stripping cuts into the operation contents: parse\n  // either throws or recovers a truncated parse whose forge does not match. So a\n  // clean round-trip is what proves the trailing bytes were a signature.\n  const operationBytes = serialized.slice(0, -SIGNATURE_HEX_LENGTH);\n  try {\n    const parsed = await localForger.parse(operationBytes);\n    const roundTrip = await localForger.forge(parsed);\n    if (roundTrip !== operationBytes) {\n      return undefined;\n    }\n    return { parsed, transactionId: await Utils.calculateTransactionId(serialized) };\n  } catch (_) {\n    return undefined;\n  }\n}\n\n/**\n * Tezos transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  private _parsedTransaction?: ParsedTransaction; // transaction in JSON format\n  private _encodedTransaction?: string; // transaction in hex format\n  private _source: string;\n  private _delegate?: string;\n  private _forwarderDestination?: string;\n  private _publicKeyToReveal?: string;\n  private _owners: string[];\n\n  /**\n   * Public constructor.\n   *\n   * @param {Readonly<CoinConfig>} coinConfig\n   */\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._owners = [];\n  }\n\n  /**\n   * Initialize the transaction fields based on another serialized transaction.\n   *\n   * @param serializedTransaction Transaction in broadcast format.\n   */\n  async initFromSerializedTransaction(serializedTransaction: string): Promise<void> {\n    this._encodedTransaction = serializedTransaction;\n    // Only signed inputs have a transaction id (it is the hash of the signed bytes);\n    // unsigned inputs leave it unset and let the caller populate it after signing.\n    const signed = await tryParseSigned(serializedTransaction);\n    if (signed) {\n      // TODO: encode the signature and save it in _signature\n      await this.initFromParsedTransaction(signed.parsed, signed.transactionId);\n      return;\n    }\n    const parsed = await localForger.parse(serializedTransaction);\n    await this.initFromParsedTransaction(parsed);\n  }\n\n  /**\n   * Initialize the transaction fields based on another parsed transaction.\n   *\n   * @param {ParsedTransaction} parsedTransaction A Tezos transaction object\n   * @param {string} transactionId The transaction id of the parsedTransaction if it is signed\n   */\n  async initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void> {\n    if (!this._encodedTransaction) {\n      this._encodedTransaction = await localForger.forge(parsedTransaction);\n    }\n    if (transactionId) {\n      this._id = transactionId;\n      this._inputs = [];\n      this._outputs = [];\n    } else {\n      this._id = '';\n    }\n    this._parsedTransaction = parsedTransaction;\n    let operationIndex = 0;\n    for (const operation of parsedTransaction.contents) {\n      // Narrowing: only operations with a source have a source field\n      if ('source' in operation) {\n        if (this._source && this._source !== operation.source) {\n          throw new InvalidTransactionError(\n            `Source must be the same for every operation but it changed from ${this._source} to ${operation.source}`\n          );\n        } else {\n          this._source = operation.source;\n        }\n      }\n\n      switch (operation.kind) {\n        case OpKind.ORIGINATION:\n          await this.recordOriginationOpFields(operation as OriginationOp, operationIndex);\n          operationIndex++;\n          break;\n        case OpKind.REVEAL:\n          this.recordRevealOpFields(operation as RevealOp);\n          break;\n        case OpKind.TRANSACTION:\n          this.recordTransactionOpFields(operation as TransactionOp);\n          break;\n        default:\n          break; // skip operations like attestations, endorsements, etc.\n      }\n    }\n  }\n\n  /**\n   * Record the most important fields from an origination operation.\n   *\n   * @param {Operation} operation An operation object from a Tezos transaction\n   * @param {number} index The origination operation index in the transaction. Used to calculate the\n   *      originated address\n   */\n  private async recordOriginationOpFields(operation: OriginationOp, index: number): Promise<void> {\n    const originationData = getOriginationDataFromOperation(operation);\n    if (originationData.forwarderDestination) {\n      this._type = TransactionType.AddressInitialization;\n      this._forwarderDestination = originationData.forwarderDestination;\n    } else {\n      this._type = TransactionType.WalletInitialization;\n      this._owners = getOwnersPublicKeys(operation);\n    }\n\n    this._delegate = operation.delegate;\n    this._outputs.push({\n      // Kt addresses can only be calculated for signed transactions with an id\n      address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',\n      // Balance\n      value: operation.balance,\n    });\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: new BigNumber(operation.balance).plus(operation.fee).toString(),\n    });\n  }\n\n  /**\n   * Record the most important fields from a reveal operation.\n   *\n   * @param {RevealOp} operation A reveal operation object from a Tezos transaction\n   */\n  private recordRevealOpFields(operation: RevealOp): void {\n    this._type = TransactionType.AccountUpdate;\n    this._publicKeyToReveal = operation.public_key;\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: operation.fee,\n    });\n  }\n\n  /**\n   * Record the most important fields for a Transaction operation.\n   *\n   * @param {TransactionOp} operation A transaction object from a Tezos operation\n   */\n  private recordTransactionOpFields(operation: TransactionOp): void {\n    if (operation.parameters) {\n      this._type = TransactionType.Send;\n    } else {\n      this._type = TransactionType.SingleSigSend;\n    }\n    const transferData = getMultisigTransferDataFromOperation(operation);\n    // Fees are paid by the source account, along with the amount in the transaction\n    this._inputs.push({\n      address: operation.source,\n      value: new BigNumber(transferData.fee.fee).toFixed(0),\n    });\n\n    if (transferData.coin === 'mutez') {\n      this._outputs.push({\n        // Kt addresses can only be calculated for signed transactions with an id\n        address: transferData.to,\n        // Balance\n        value: transferData.amount,\n      });\n      // The funds being transferred from the wallet\n      this._inputs.push({\n        address: transferData.from,\n        // Balance + fees + max gas + max storage are paid by the source account\n        value: transferData.amount,\n      });\n    }\n  }\n\n  /**\n   * Sign the transaction with the provided key. It does not check if the signer is allowed to sign\n   * it or not.\n   *\n   * @param {KeyPair} keyPair The key to sign the transaction with\n   */\n  async sign(keyPair: KeyPair): Promise<void> {\n    // TODO: fail if the transaction is already signed\n    // Check if there is a transaction to sign\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // Get the transaction body to sign\n    const encodedTransaction = await localForger.forge(this._parsedTransaction);\n\n    const signedTransaction = await Utils.sign(keyPair, encodedTransaction);\n    this._encodedTransaction = signedTransaction.sbytes;\n\n    // The transaction id can only be calculated for signed transactions\n    this._id = await Utils.calculateTransactionId(this._encodedTransaction);\n    await this.initFromParsedTransaction(this._parsedTransaction, this._id);\n\n    this._signatures.push(signedTransaction.sig);\n  }\n\n  /**\n   * Update the list of signatures for a multisig transaction operation.\n   *\n   * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on\n   *    in the multisig transfer\n   * @param {number} index The transfer index to add the signatures to\n   */\n  async addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void> {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    updateMultisigTransferSignatures(this._parsedTransaction.contents[index] as TransactionOp, signatures);\n    this._encodedTransaction = await localForger.forge(this._parsedTransaction);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // TODO: check the key belongs to the _source account in _parsedTransaction\n    return true;\n  }\n\n  /** @inheritdoc */\n  toJson(): ParsedTransaction {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this._parsedTransaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._encodedTransaction) {\n      throw new InvalidTransactionError('Missing encoded transaction');\n    }\n    return this._encodedTransaction;\n  }\n\n  /**\n   * Get the transaction source if it is available.\n   *\n   * @returns {string} Source of the transaction\n   */\n  get source(): string {\n    if (!this._source) {\n      throw new InvalidTransactionError('Transaction not initialized');\n    }\n    return this._source;\n  }\n\n  /**\n   * Get the transaction delegation address if it is available.\n   *\n   * @returns {string} transaction delegation address\n   */\n  get delegate(): string | undefined {\n    return this._delegate;\n  }\n\n  /**\n   * Get the public key revealed by the transaction if it exists\n   *\n   * @returns {string} public key\n   */\n  get publicKeyToReveal(): string | undefined {\n    return this._publicKeyToReveal;\n  }\n\n  /**\n   * Get the destination of an address initialization transaction if it exists\n   *\n   * @returns {string} forwarder destination\n   */\n  get forwarderDestination(): string | undefined {\n    return this._forwarderDestination;\n  }\n\n  get owners(): string[] {\n    return this._owners;\n  }\n\n  /**\n   * Get the signatures for the given multisig transfer,\n   *\n   * @param {number} transferIndex The transfer script index in the Tezos transaction\n   * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer\n   *      script\n   */\n  getTransferSignatures(transferIndex = 0): IndexedSignature[] {\n    if (!this._parsedTransaction) {\n      return [];\n    }\n    return getMultisigTransferSignatures(this._parsedTransaction.contents[transferIndex] as TransactionOp);\n  }\n\n  /**\n   * Get the list of index per tezos transaction type. This is useful to locate specific operations\n   * within the transaction and verify or sign them.\n   *\n   * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind\n   */\n  getIndexesByTransactionType(): { [kind: string]: number[] } {\n    if (!this._parsedTransaction) {\n      return {};\n    }\n    const indexes = {};\n    for (let i = 0; i < this._parsedTransaction.contents.length; i++) {\n      const kind = this._parsedTransaction.contents[i].kind;\n      indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];\n    }\n    return indexes;\n  }\n}\n"]}
@@ -8,6 +8,13 @@ const should_1 = __importDefault(require("should"));
8
8
  const statics_1 = require("@bitgo/statics");
9
9
  const resources_1 = require("../resources");
10
10
  const src_1 = require("../../src");
11
+ // Signing the fixture origination with this seed produces a 64-byte signature
12
+ // whose bytes are coincidentally valid Michelson contents.
13
+ function signerSeedProducingMichelsonShapedSignature() {
14
+ const seed = Buffer.alloc(16);
15
+ seed.writeUInt32BE(174, 0);
16
+ return seed;
17
+ }
11
18
  describe('Tezos transaction', function () {
12
19
  describe('should parse', () => {
13
20
  it('unsigned transaction', async () => {
@@ -38,6 +45,22 @@ describe('Tezos transaction', function () {
38
45
  JSON.stringify(tx.toJson()).should.equal(JSON.stringify(resources_1.parsedTransaction));
39
46
  tx.toBroadcastFormat().should.equal(resources_1.signedSerializedOriginationTransaction);
40
47
  });
48
+ it('signed transaction whose signature suffix forges as valid Michelson', async () => {
49
+ const signerWithMichelsonShapedSignature = new src_1.XtzLib.KeyPair({
50
+ seed: signerSeedProducingMichelsonShapedSignature(),
51
+ });
52
+ const signedTx = new src_1.XtzLib.Transaction(statics_1.coins.get('txtz'));
53
+ await signedTx.initFromSerializedTransaction(resources_1.unsignedSerializedOriginationTransaction);
54
+ await signedTx.sign(signerWithMichelsonShapedSignature);
55
+ const signedBytes = signedTx.toBroadcastFormat();
56
+ const expectedTxId = signedTx.id;
57
+ expectedTxId.should.match(/^o[a-zA-Z0-9]+$/);
58
+ const reparsed = new src_1.XtzLib.Transaction(statics_1.coins.get('txtz'));
59
+ await reparsed.initFromSerializedTransaction(signedBytes);
60
+ reparsed.id.should.equal(expectedTxId);
61
+ reparsed.outputs.length.should.equal(1);
62
+ reparsed.outputs[0].address.should.startWith('KT1');
63
+ });
41
64
  });
42
65
  describe('should sign', () => {
43
66
  it('an unsigned origination transaction', async () => {
@@ -98,4 +121,4 @@ describe('Tezos transaction', function () {
98
121
  });
99
122
  });
100
123
  });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../test/unit/transaction.ts"],"names":[],"mappings":";;;;;AAAA,oDAA4B;AAC5B,oDAA4B;AAC5B,4CAAuC;AACvC,4CAIsB;AAEtB,mCAAmC;AAEnC,QAAQ,CAAC,mBAAmB,EAAE;IAC5B,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;QAC5B,EAAE,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;YACpC,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,6BAA6B,CAAC,oDAAwC,CAAC,CAAC;YAEjF,gBAAM,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1E,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC3C,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACvC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5C,gBAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC9B,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,6BAAiB,CAAC,CAAC,CAAC;YAC5E,EAAE,CAAC,iBAAiB,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,oDAAwC,CAAC,CAAC;QAChF,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;YAClC,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,6BAA6B,CAAC,kDAAsC,CAAC,CAAC;YAE/E,gBAAM,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1E,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC3C,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC3E,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5C,gBAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC9B,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,6BAAiB,CAAC,CAAC,CAAC;YAC5E,EAAE,CAAC,iBAAiB,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,kDAAsC,CAAC,CAAC;QAC9E,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;YACnD,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,6BAA6B,CAAC,oDAAwC,CAAC,CAAC;YAEjF,MAAM,MAAM,GAAG,IAAI,YAAM,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,wDAAwD,EAAE,CAAC,CAAC;YACrG,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACtB,gBAAM,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1E,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC3C,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC3E,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5C,gBAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC9B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACpC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAC1B,kGAAkG,CACnG,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;YAChD,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,6BAA6B,CAAC,kDAAsC,CAAC,CAAC;YAE/E,MAAM,MAAM,GAAG,IAAI,YAAM,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,wDAAwD,EAAE,CAAC,CAAC;YACrG,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACtB,gBAAM,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC1E,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC3C,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAClC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC3E,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAC5C,gBAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC9B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACpC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAC1B,kGAAkG,CACnG,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;YACvD,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,yBAAyB,CAAC,EAAwC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC;QACpG,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;YAC1D,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,gBAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;YACnD,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,MAAM,GAAG,IAAI,YAAM,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,wDAAwD,EAAE,CAAC,CAAC;YACrG,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;YAC/D,MAAM,EAAE,GAAG,IAAI,YAAM,CAAC,WAAW,CAAC,eAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,MAAM,EAAE,CAAC,yBAAyB,CAAC;gBACjC,GAAG,6BAAiB;gBACpB,QAAQ,EAAE,6BAAiB,CAAC,QAA+B;aAC5D,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,IAAI,YAAM,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,yDAAyD,EAAE,CAAC,CAAC;YACtG,MAAM,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import assert from 'assert';\nimport should from 'should';\nimport { coins } from '@bitgo/statics';\nimport {\n  unsignedSerializedOriginationTransaction,\n  signedSerializedOriginationTransaction,\n  parsedTransaction,\n} from '../resources';\nimport { OperationContents } from '@taquito/rpc';\nimport { XtzLib } from '../../src';\n\ndescribe('Tezos transaction', function () {\n  describe('should parse', () => {\n    it('unsigned transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(unsignedSerializedOriginationTransaction);\n\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      JSON.stringify(tx.toJson()).should.equal(JSON.stringify(parsedTransaction));\n      tx.toBroadcastFormat().should.equal(unsignedSerializedOriginationTransaction);\n    });\n\n    it('signed transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(signedSerializedOriginationTransaction);\n\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1LJvp55fbdNwbisJFign9wA4cPgq9T9oc4');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      JSON.stringify(tx.toJson()).should.equal(JSON.stringify(parsedTransaction));\n      tx.toBroadcastFormat().should.equal(signedSerializedOriginationTransaction);\n    });\n  });\n\n  describe('should sign', () => {\n    it('an unsigned origination transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(unsignedSerializedOriginationTransaction);\n\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer);\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1Dh62qPZhJvMMtL4rAnDS2uASptT6GNLMy');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      tx.signature.length.should.equal(1);\n      tx.signature[0].should.equal(\n        'sigu3cjQh8rf79aXG555fRxKzuTa2byZnvMJqkJENpdKjEwCri6SUM9fLywDC3w8e6dHRT8RRaJVQiijC9yzwqL6FSm2Jj9a'\n      );\n    });\n\n    it('a signed origination transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(signedSerializedOriginationTransaction);\n\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer);\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1Dh62qPZhJvMMtL4rAnDS2uASptT6GNLMy');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      tx.signature.length.should.equal(1);\n      tx.signature[0].should.equal(\n        'sigu3cjQh8rf79aXG555fRxKzuTa2byZnvMJqkJENpdKjEwCri6SUM9fLywDC3w8e6dHRT8RRaJVQiijC9yzwqL6FSm2Jj9a'\n      );\n    });\n  });\n\n  describe('should fail', () => {\n    it('to parse and invalid parsed transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromParsedTransaction({} as XtzLib.Interface.ParsedTransaction).should.be.rejected();\n    });\n\n    it('to get the transaction JSON if it is empty', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      assert.throws(() => tx.toJson());\n    });\n\n    it('to sign if the transaction is empty', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer).should.be.rejectedWith('Empty transaction');\n    });\n\n    it('to sign the transaction if the keys are invalid', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromParsedTransaction({\n        ...parsedTransaction,\n        contents: parsedTransaction.contents as OperationContents[],\n      });\n      const signer = new XtzLib.KeyPair({ pub: 'sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b' });\n      await tx.sign(signer).should.be.rejectedWith('Missing private key');\n    });\n  });\n});\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../test/unit/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\nimport { coins } from '@bitgo/statics';\nimport {\n  unsignedSerializedOriginationTransaction,\n  signedSerializedOriginationTransaction,\n  parsedTransaction,\n} from '../resources';\nimport { OperationContents } from '@taquito/rpc';\nimport { XtzLib } from '../../src';\n\n// Signing the fixture origination with this seed produces a 64-byte signature\n// whose bytes are coincidentally valid Michelson contents.\nfunction signerSeedProducingMichelsonShapedSignature(): Buffer {\n  const seed = Buffer.alloc(16);\n  seed.writeUInt32BE(174, 0);\n  return seed;\n}\n\ndescribe('Tezos transaction', function () {\n  describe('should parse', () => {\n    it('unsigned transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(unsignedSerializedOriginationTransaction);\n\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      JSON.stringify(tx.toJson()).should.equal(JSON.stringify(parsedTransaction));\n      tx.toBroadcastFormat().should.equal(unsignedSerializedOriginationTransaction);\n    });\n\n    it('signed transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(signedSerializedOriginationTransaction);\n\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1LJvp55fbdNwbisJFign9wA4cPgq9T9oc4');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      JSON.stringify(tx.toJson()).should.equal(JSON.stringify(parsedTransaction));\n      tx.toBroadcastFormat().should.equal(signedSerializedOriginationTransaction);\n    });\n\n    it('signed transaction whose signature suffix forges as valid Michelson', async () => {\n      const signerWithMichelsonShapedSignature = new XtzLib.KeyPair({\n        seed: signerSeedProducingMichelsonShapedSignature(),\n      });\n\n      const signedTx = new XtzLib.Transaction(coins.get('txtz'));\n      await signedTx.initFromSerializedTransaction(unsignedSerializedOriginationTransaction);\n      await signedTx.sign(signerWithMichelsonShapedSignature);\n      const signedBytes = signedTx.toBroadcastFormat();\n      const expectedTxId = signedTx.id;\n      expectedTxId.should.match(/^o[a-zA-Z0-9]+$/);\n\n      const reparsed = new XtzLib.Transaction(coins.get('txtz'));\n      await reparsed.initFromSerializedTransaction(signedBytes);\n\n      reparsed.id.should.equal(expectedTxId);\n      reparsed.outputs.length.should.equal(1);\n      reparsed.outputs[0].address.should.startWith('KT1');\n    });\n  });\n\n  describe('should sign', () => {\n    it('an unsigned origination transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(unsignedSerializedOriginationTransaction);\n\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer);\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1Dh62qPZhJvMMtL4rAnDS2uASptT6GNLMy');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      tx.signature.length.should.equal(1);\n      tx.signature[0].should.equal(\n        'sigu3cjQh8rf79aXG555fRxKzuTa2byZnvMJqkJENpdKjEwCri6SUM9fLywDC3w8e6dHRT8RRaJVQiijC9yzwqL6FSm2Jj9a'\n      );\n    });\n\n    it('a signed origination transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromSerializedTransaction(signedSerializedOriginationTransaction);\n\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer);\n      should.equal(tx.inputs.length, 1);\n      tx.inputs.length.should.equal(1);\n      tx.inputs[0].address.should.equal('tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A');\n      tx.inputs[0].value.should.equal('1004764');\n      tx.outputs.length.should.equal(1);\n      tx.outputs[0].address.should.equal('KT1Dh62qPZhJvMMtL4rAnDS2uASptT6GNLMy');\n      tx.outputs[0].value.should.equal('1000000');\n      should.not.exist(tx.delegate);\n      tx.signature.length.should.equal(1);\n      tx.signature[0].should.equal(\n        'sigu3cjQh8rf79aXG555fRxKzuTa2byZnvMJqkJENpdKjEwCri6SUM9fLywDC3w8e6dHRT8RRaJVQiijC9yzwqL6FSm2Jj9a'\n      );\n    });\n  });\n\n  describe('should fail', () => {\n    it('to parse and invalid parsed transaction', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromParsedTransaction({} as XtzLib.Interface.ParsedTransaction).should.be.rejected();\n    });\n\n    it('to get the transaction JSON if it is empty', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      assert.throws(() => tx.toJson());\n    });\n\n    it('to sign if the transaction is empty', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      const signer = new XtzLib.KeyPair({ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL' });\n      await tx.sign(signer).should.be.rejectedWith('Empty transaction');\n    });\n\n    it('to sign the transaction if the keys are invalid', async () => {\n      const tx = new XtzLib.Transaction(coins.get('txtz'));\n      await tx.initFromParsedTransaction({\n        ...parsedTransaction,\n        contents: parsedTransaction.contents as OperationContents[],\n      });\n      const signer = new XtzLib.KeyPair({ pub: 'sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b' });\n      await tx.sign(signer).should.be.rejectedWith('Missing private key');\n    });\n  });\n});\n"]}