UNPKG

cache-typescript-sdk

Version:
102 lines 4.04 kB
"use strict"; /* * The MIT License (MIT) * * Copyright (c) 2017 NEM * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ Object.defineProperty(exports, "__esModule", { value: true }); const Transaction_1 = require("./Transaction"); const TransactionTypes_1 = require("./TransactionTypes"); /** * Multisig transaction are the only way to make transaction from a multisig account to another account. * A multisig transaction carries another transaction inside (often referred to as "inner" transaction). * The inner transaction can be a transfer, an importance transfer or an aggregate modification transaction. * A multisig transaction also has multisig signature transactions from the cosignatories of the multisig account inside. */ class MultisigTransaction extends Transaction_1.Transaction { /** * @internal * @param timeWindow * @param version * @param otherTrans * @param fee * @param signatures * @param signature * @param sender * @param transactionInfo * @param hashData */ constructor(timeWindow, version, otherTrans, fee, signatures, signature, sender, transactionInfo, hashData) { super(TransactionTypes_1.TransactionTypes.MULTISIG, version, timeWindow, signature, sender, transactionInfo); this.otherTransaction = otherTrans; this.hashData = hashData; this.fee = fee; this.signatures = signatures; } /** * Check if transaction is pending to sign * @returns {boolean} */ isPendingToSign() { return this.transactionInfo == null && this.hashData != null; } /** * Create a MultisigTransaction object * @param timeWindow * @param otherTrans * @param multisig * @returns {MultisigTransaction} */ static create(timeWindow, otherTrans, multisig) { const fee = Math.floor(3 * 0.05 * 1000000); otherTrans.signer = multisig; return new MultisigTransaction(timeWindow, 1, otherTrans, fee, []); } /** * @internal * @param networkType */ setNetworkType(networkType) { super.setNetworkType(networkType); this.otherTransaction.setNetworkType(networkType); } // region boilerplate /** * Create DTO of MultisigTransaction * @returns {MultisigTransactionDTO} */ toDTO() { const version = this.networkVersion ? this.networkVersion : this.version; return this.serializeDTO({ signer: this.signer ? this.signer.publicKey : undefined, deadline: this.timeWindow.deadlineToDTO(), timeStamp: this.timeWindow.timeStampToDTO(), type: this.type, signature: this.signature, signatures: this.signatures.map((signature) => signature.toDTO()), version, fee: this.fee, otherTrans: this.otherTransaction.toDTO(), }); } } exports.MultisigTransaction = MultisigTransaction; //# sourceMappingURL=MultisigTransaction.js.map