@bitgo-beta/sdk-core 8.2.1-beta.846 → 8.2.1-beta.848
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.
|
@@ -19,6 +19,7 @@ export declare abstract class BaseTransactionBuilder {
|
|
|
19
19
|
* extending this class. Some examples are hex, base64, or JSON.
|
|
20
20
|
*
|
|
21
21
|
* @param rawTransaction A raw transaction to be parsed
|
|
22
|
+
* @param isFirstSigner Whether the transaction is being signed by the first signer
|
|
22
23
|
*/
|
|
23
24
|
from(rawTransaction: any, isFirstSigner?: boolean): void;
|
|
24
25
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"baseTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD;;;GAGG;AACH,8BAAsB,sBAAsB;IAC1C,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAIvD
|
|
1
|
+
{"version":3,"file":"baseTransactionBuilder.d.ts","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAGpD;;;GAGG;AACH,8BAAsB,sBAAsB;IAC1C,SAAS,CAAC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC5C;;;;OAIG;IACH,SAAS,aAAa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAIvD;;;;;;OAMG;IACH,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,aAAa,CAAC,EAAE,OAAO,GAAG,IAAI;IAKxD;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,cAAc,EAAE,GAAG,EAAE,aAAa,CAAC,EAAE,OAAO,GAAG,eAAe;IAEpG;;;;OAIG;IACH,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IASxB;;;;;OAKG;IACH,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI3D;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,eAAe;IAEpE;;;;;OAKG;IACG,KAAK,IAAI,OAAO,CAAC,eAAe,CAAC;IAKvC;;;;;OAKG;IACH,SAAS,CAAC,QAAQ,CAAC,mBAAmB,IAAI,OAAO,CAAC,eAAe,CAAC;IAElE;;;;OAIG;IACH,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAExC;;;;;OAKG;IACH,QAAQ,CAAC,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAE5E;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAE9C;;;;OAIG;IACH,QAAQ,CAAC,sBAAsB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAE1D;;;;;OAKG;IACH,QAAQ,CAAC,mBAAmB,CAAC,WAAW,CAAC,EAAE,eAAe,GAAG,IAAI;IAEjE;;OAEG;IACH,WAAW,IAAI,MAAM;IAIrB;;OAEG;IACH,QAAQ,IAAI,MAAM;IAIlB;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAM,EAAE,cAAc,GAAG,cAAc;IAyDzD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,IAAI,eAAe,CAAC;IAEtD;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,WAAW,CAAC,WAAW,EAAE,eAAe,EAAE;CAClE"}
|
|
@@ -20,6 +20,7 @@ class BaseTransactionBuilder {
|
|
|
20
20
|
* extending this class. Some examples are hex, base64, or JSON.
|
|
21
21
|
*
|
|
22
22
|
* @param rawTransaction A raw transaction to be parsed
|
|
23
|
+
* @param isFirstSigner Whether the transaction is being signed by the first signer
|
|
23
24
|
*/
|
|
24
25
|
from(rawTransaction, isFirstSigner) {
|
|
25
26
|
this.validateRawTransaction(rawTransaction);
|
|
@@ -135,4 +136,4 @@ class BaseTransactionBuilder {
|
|
|
135
136
|
}
|
|
136
137
|
}
|
|
137
138
|
exports.BaseTransactionBuilder = BaseTransactionBuilder;
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":";;;AAIA,qCAAwC;AAExC;;;GAGG;AACH,MAAsB,sBAAsB;IAE1C;;;;OAIG;IACH,YAAsB,WAAiC;QACrD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACH,IAAI,CAAC,cAAmB,EAAE,aAAuB;QAC/C,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC;IAC5E,CAAC;IAUD;;;;OAIG;IACH,IAAI,CAAC,GAAY;QACf,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,qBAAY,CAAC,yCAAyC,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,SAAoB,EAAE,SAAiB;QAClD,MAAM,IAAI,qBAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,+CAA+C,CAAC,CAAC;IAC5F,CAAC;IAUD;;;;;OAKG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACpC,CAAC;IA+CD;;OAEG;IACH,WAAW;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAC/B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAsB;QACtC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,EAAE,CAAC;YACnF,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,IAAI,kBAA0B,CAAC;QAC/B,IAAI,kBAA0B,CAAC;QAC/B,IAAI,iBAAyB,CAAC;QAC9B,IAAI,gBAAwB,CAAC;QAE7B;;;WAGG;QACH,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,WAAW,CAAC;YACjC,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAC/B,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,OAAO,CAAC;YAC7B,iBAAiB,GAAG,CAAC,CAAC;YACtB,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;QAED,oFAAoF;QACpF,IAAI,UAAU,GAAW,MAAM,CAAC,UAAU,IAAI,iBAAiB,CAAC;QAChE,IAAI,SAAS,GAAW,MAAM,CAAC,SAAS,IAAI,gBAAgB,CAAC;QAC7D,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QACnE,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QAEnE;;;;WAIG;QACH,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,qCAAqC,WAAW,GAAG,CAAC,CAAC;QAC3G,CAAC;QACD,UAAU,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC;QAC9D,WAAW,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAClE,WAAW,GAAG,WAAW,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAC3E,SAAS;YACP,SAAS,IAAI,UAAU,GAAG,WAAW,IAAI,SAAS,IAAI,UAAU,GAAG,WAAW;gBAC5E,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,UAAU,GAAG,WAAW,CAAC;QAE/B,OAAO;YACL,UAAU;YACV,SAAS;YACT,WAAW;YACX,WAAW;YACX,IAAI;SACL,CAAC;IACJ,CAAC;CAWF;AAlND,wDAkNC","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';\nimport { BaseTransaction } from './baseTransaction';\nimport { SigningError } from './errors';\n\n/**\n * Generic transaction builder to be extended with coin specific logic.\n * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.\n */\nexport abstract class BaseTransactionBuilder {\n  protected _coinConfig: Readonly<CoinConfig>;\n  /**\n   * Base constructor.\n   *\n   * @param _coinConfig BaseCoin from statics library\n   */\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = _coinConfig;\n  }\n\n  /**\n   * Parse a transaction based on existing data. The input format is determined by the coin\n   * extending this class. Some examples are hex, base64, or JSON.\n   *\n   * @param rawTransaction A raw transaction to be parsed\n   */\n  from(rawTransaction: any, isFirstSigner?: boolean): void {\n    this.validateRawTransaction(rawTransaction);\n    this.transaction = this.fromImplementation(rawTransaction, isFirstSigner);\n  }\n\n  /**\n   * Coin specific implementation of {@code from}.\n   *\n   * @see {@link from}\n   * @returns the parsed coin specific transaction object\n   */\n  protected abstract fromImplementation(rawTransaction: any, isFirstSigner?: boolean): BaseTransaction;\n\n  /**\n   * Validate keys and sign the transaction.\n   *\n   * @param key One of the keys associated with this transaction\n   */\n  sign(key: BaseKey): void {\n    this.validateKey(key);\n    if (!this.transaction.canSign(key)) {\n      throw new SigningError('Private key cannot sign the transaction');\n    }\n\n    this.transaction = this.signImplementation(key);\n  }\n\n  /**\n   * Adds a signature to the transaction.\n   *\n   * @param publicKey public key that produced the signature\n   * @param signature raw signature as a hex encoded Buffer\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    throw new SigningError(`${this.coinName()} does not support adding signatures directly.`);\n  }\n\n  /**\n   * Coin specific implementation of {@code sign}.\n   *\n   * @see {@link sign}\n   * @returns coin specific transaction with signature data\n   */\n  protected abstract signImplementation(key: BaseKey): BaseTransaction;\n\n  /**\n   * Finalize the transaction by performing any extra step like calculating hashes, verifying\n   * integrity, or adding default values.\n   *\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  async build(): Promise<BaseTransaction> {\n    this.validateTransaction(this.transaction);\n    return this.buildImplementation();\n  }\n\n  /**\n   * Coin specific implementation of {@code build}.\n   *\n   * @see {@link build}\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  protected abstract buildImplementation(): Promise<BaseTransaction>;\n\n  /**\n   * Check the private key is present and is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BaseKey} key Private key to validate\n   */\n  abstract validateKey(key: BaseKey): void;\n\n  /**\n   * Check the address provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param address Address data to be validated\n   * @param addressFormat The format the address should be in if more than one is supported\n   */\n  abstract validateAddress(address: BaseAddress, addressFormat?: string): void;\n\n  /**\n   * Check the amount provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BigNumber} value Transaction amount\n   */\n  abstract validateValue(value: BigNumber): void;\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param rawTransaction Transaction in any format\n   */\n  abstract validateRawTransaction(rawTransaction: any): void;\n\n  /**\n   * Check the transaction mandatory fields per transaction type and ensures it is valid, throw\n   * otherwise.\n   *\n   * @param {BaseTransaction} transaction\n   */\n  abstract validateTransaction(transaction?: BaseTransaction): void;\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  displayName(): string {\n    return this._coinConfig.fullName;\n  }\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  coinName(): string {\n    return this._coinConfig.name;\n  }\n\n  /**\n   * Verified validity windows params if them exist and return a valid validity windows.\n   * Unit param must be specified\n   * If params are not consistent, default params will be return based on firstValid and minDuration\n   * @param {ValidityWindow} params validity windows parameters to validate.\n   * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'\n   * @param {Number} [params.minDuration] Optional - Minimum duration of the window\n   * @param {Number} [params.maxDuration] Optional - Maximum duration of the window\n   * @param {Number} [params.firstValid] Optional - First valid value\n   * @param {Number} [params.lastValid] Optional - Last valid value\n   * @returns {ValidityWindow} verified validity windows or default values\n   */\n  getValidityWindow(params: ValidityWindow): ValidityWindow {\n    if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {\n      throw new Error('Unit parameter must be specified as blockheight or timestamp');\n    }\n    const unit = params.unit;\n    let defaultMinDuration: number;\n    let defaultMaxDuration: number;\n    let defaultFirstValid: number;\n    let defaultLastValid: number;\n\n    /* Set Default Params\n      minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight\n      maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.\n     */\n    if (unit === 'timestamp') {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 31536000000;\n      defaultFirstValid = Date.now();\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    } else {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 1000000;\n      defaultFirstValid = 0;\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    }\n\n    // If any params exist, they will be used, otherwise it will be used default params.\n    let firstValid: number = params.firstValid || defaultFirstValid;\n    let lastValid: number = params.lastValid || defaultLastValid;\n    let minDuration: number = params.minDuration || defaultMinDuration;\n    let maxDuration: number = params.maxDuration || defaultMaxDuration;\n\n    /* Validate Params:\n      minDuration < maxDuration\n      firstValid < lastValid\n      firstValid + minDuration <= lastValid <= firstValid + maxDuration\n     */\n    if (minDuration >= maxDuration) {\n      throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);\n    }\n    firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;\n    minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;\n    maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;\n    lastValid =\n      lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration\n        ? lastValid\n        : firstValid + maxDuration;\n\n    return {\n      firstValid,\n      lastValid,\n      minDuration,\n      maxDuration,\n      unit,\n    };\n  }\n\n  /**\n   * Get the transaction being built.\n   */\n  protected abstract get transaction(): BaseTransaction;\n\n  /**\n   * Set the transaction being built.\n   */\n  protected abstract set transaction(transaction: BaseTransaction);\n}\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":";;;AAIA,qCAAwC;AAExC;;;GAGG;AACH,MAAsB,sBAAsB;IAE1C;;;;OAIG;IACH,YAAsB,WAAiC;QACrD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACH,IAAI,CAAC,cAAmB,EAAE,aAAuB;QAC/C,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC;IAC5E,CAAC;IAUD;;;;OAIG;IACH,IAAI,CAAC,GAAY;QACf,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,qBAAY,CAAC,yCAAyC,CAAC,CAAC;QACpE,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;IAClD,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,SAAoB,EAAE,SAAiB;QAClD,MAAM,IAAI,qBAAY,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,+CAA+C,CAAC,CAAC;IAC5F,CAAC;IAUD;;;;;OAKG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACpC,CAAC;IA+CD;;OAEG;IACH,WAAW;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;IAC/B,CAAC;IAED;;;;;;;;;;;OAWG;IACH,iBAAiB,CAAC,MAAsB;QACtC,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,WAAW,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,EAAE,CAAC;YACnF,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;QACzB,IAAI,kBAA0B,CAAC;QAC/B,IAAI,kBAA0B,CAAC;QAC/B,IAAI,iBAAyB,CAAC;QAC9B,IAAI,gBAAwB,CAAC;QAE7B;;;WAGG;QACH,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,WAAW,CAAC;YACjC,iBAAiB,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAC/B,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,kBAAkB,GAAG,CAAC,CAAC;YACvB,kBAAkB,GAAG,OAAO,CAAC;YAC7B,iBAAiB,GAAG,CAAC,CAAC;YACtB,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,CAAC;QAC5D,CAAC;QAED,oFAAoF;QACpF,IAAI,UAAU,GAAW,MAAM,CAAC,UAAU,IAAI,iBAAiB,CAAC;QAChE,IAAI,SAAS,GAAW,MAAM,CAAC,SAAS,IAAI,gBAAgB,CAAC;QAC7D,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QACnE,IAAI,WAAW,GAAW,MAAM,CAAC,WAAW,IAAI,kBAAkB,CAAC;QAEnE;;;;WAIG;QACH,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,qCAAqC,WAAW,GAAG,CAAC,CAAC;QAC3G,CAAC;QACD,UAAU,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC;QAC9D,WAAW,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAClE,WAAW,GAAG,WAAW,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,kBAAkB,CAAC;QAC3E,SAAS;YACP,SAAS,IAAI,UAAU,GAAG,WAAW,IAAI,SAAS,IAAI,UAAU,GAAG,WAAW;gBAC5E,CAAC,CAAC,SAAS;gBACX,CAAC,CAAC,UAAU,GAAG,WAAW,CAAC;QAE/B,OAAO;YACL,UAAU;YACV,SAAS;YACT,WAAW;YACX,WAAW;YACX,IAAI;SACL,CAAC;IACJ,CAAC;CAWF;AAnND,wDAmNC","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';\nimport { BaseTransaction } from './baseTransaction';\nimport { SigningError } from './errors';\n\n/**\n * Generic transaction builder to be extended with coin specific logic.\n * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.\n */\nexport abstract class BaseTransactionBuilder {\n  protected _coinConfig: Readonly<CoinConfig>;\n  /**\n   * Base constructor.\n   *\n   * @param _coinConfig BaseCoin from statics library\n   */\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = _coinConfig;\n  }\n\n  /**\n   * Parse a transaction based on existing data. The input format is determined by the coin\n   * extending this class. Some examples are hex, base64, or JSON.\n   *\n   * @param rawTransaction A raw transaction to be parsed\n   * @param isFirstSigner Whether the transaction is being signed by the first signer\n   */\n  from(rawTransaction: any, isFirstSigner?: boolean): void {\n    this.validateRawTransaction(rawTransaction);\n    this.transaction = this.fromImplementation(rawTransaction, isFirstSigner);\n  }\n\n  /**\n   * Coin specific implementation of {@code from}.\n   *\n   * @see {@link from}\n   * @returns the parsed coin specific transaction object\n   */\n  protected abstract fromImplementation(rawTransaction: any, isFirstSigner?: boolean): BaseTransaction;\n\n  /**\n   * Validate keys and sign the transaction.\n   *\n   * @param key One of the keys associated with this transaction\n   */\n  sign(key: BaseKey): void {\n    this.validateKey(key);\n    if (!this.transaction.canSign(key)) {\n      throw new SigningError('Private key cannot sign the transaction');\n    }\n\n    this.transaction = this.signImplementation(key);\n  }\n\n  /**\n   * Adds a signature to the transaction.\n   *\n   * @param publicKey public key that produced the signature\n   * @param signature raw signature as a hex encoded Buffer\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    throw new SigningError(`${this.coinName()} does not support adding signatures directly.`);\n  }\n\n  /**\n   * Coin specific implementation of {@code sign}.\n   *\n   * @see {@link sign}\n   * @returns coin specific transaction with signature data\n   */\n  protected abstract signImplementation(key: BaseKey): BaseTransaction;\n\n  /**\n   * Finalize the transaction by performing any extra step like calculating hashes, verifying\n   * integrity, or adding default values.\n   *\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  async build(): Promise<BaseTransaction> {\n    this.validateTransaction(this.transaction);\n    return this.buildImplementation();\n  }\n\n  /**\n   * Coin specific implementation of {@code build}.\n   *\n   * @see {@link build}\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  protected abstract buildImplementation(): Promise<BaseTransaction>;\n\n  /**\n   * Check the private key is present and is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BaseKey} key Private key to validate\n   */\n  abstract validateKey(key: BaseKey): void;\n\n  /**\n   * Check the address provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param address Address data to be validated\n   * @param addressFormat The format the address should be in if more than one is supported\n   */\n  abstract validateAddress(address: BaseAddress, addressFormat?: string): void;\n\n  /**\n   * Check the amount provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BigNumber} value Transaction amount\n   */\n  abstract validateValue(value: BigNumber): void;\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param rawTransaction Transaction in any format\n   */\n  abstract validateRawTransaction(rawTransaction: any): void;\n\n  /**\n   * Check the transaction mandatory fields per transaction type and ensures it is valid, throw\n   * otherwise.\n   *\n   * @param {BaseTransaction} transaction\n   */\n  abstract validateTransaction(transaction?: BaseTransaction): void;\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  displayName(): string {\n    return this._coinConfig.fullName;\n  }\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  coinName(): string {\n    return this._coinConfig.name;\n  }\n\n  /**\n   * Verified validity windows params if them exist and return a valid validity windows.\n   * Unit param must be specified\n   * If params are not consistent, default params will be return based on firstValid and minDuration\n   * @param {ValidityWindow} params validity windows parameters to validate.\n   * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'\n   * @param {Number} [params.minDuration] Optional - Minimum duration of the window\n   * @param {Number} [params.maxDuration] Optional - Maximum duration of the window\n   * @param {Number} [params.firstValid] Optional - First valid value\n   * @param {Number} [params.lastValid] Optional - Last valid value\n   * @returns {ValidityWindow} verified validity windows or default values\n   */\n  getValidityWindow(params: ValidityWindow): ValidityWindow {\n    if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {\n      throw new Error('Unit parameter must be specified as blockheight or timestamp');\n    }\n    const unit = params.unit;\n    let defaultMinDuration: number;\n    let defaultMaxDuration: number;\n    let defaultFirstValid: number;\n    let defaultLastValid: number;\n\n    /* Set Default Params\n      minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight\n      maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.\n     */\n    if (unit === 'timestamp') {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 31536000000;\n      defaultFirstValid = Date.now();\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    } else {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 1000000;\n      defaultFirstValid = 0;\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    }\n\n    // If any params exist, they will be used, otherwise it will be used default params.\n    let firstValid: number = params.firstValid || defaultFirstValid;\n    let lastValid: number = params.lastValid || defaultLastValid;\n    let minDuration: number = params.minDuration || defaultMinDuration;\n    let maxDuration: number = params.maxDuration || defaultMaxDuration;\n\n    /* Validate Params:\n      minDuration < maxDuration\n      firstValid < lastValid\n      firstValid + minDuration <= lastValid <= firstValid + maxDuration\n     */\n    if (minDuration >= maxDuration) {\n      throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);\n    }\n    firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;\n    minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;\n    maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;\n    lastValid =\n      lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration\n        ? lastValid\n        : firstValid + maxDuration;\n\n    return {\n      firstValid,\n      lastValid,\n      minDuration,\n      maxDuration,\n      unit,\n    };\n  }\n\n  /**\n   * Get the transaction being built.\n   */\n  protected abstract get transaction(): BaseTransaction;\n\n  /**\n   * Set the transaction being built.\n   */\n  protected abstract set transaction(transaction: BaseTransaction);\n}\n"]}
|