PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-icp/dist/src/lib
Просмотр файла: unsignedTransactionBuilder.js
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.UnsignedTransactionBuilder = void 0;
const iface_1 = require("./iface");
const utils_1 = __importDefault(require("./utils"));
class UnsignedTransactionBuilder {
constructor(icpTransactionPayload) {
this._icpTransactionPayload = icpTransactionPayload;
}
async getUnsignedTransaction() {
// interval value can be altered here to change the count of ingressExpiries which eventually changes the number of interval value can be altered here to change the count of ingressExpiries which eventually changes the number of payloads that needs to be signed
const interval = Number(this._icpTransactionPayload.metadata.ingress_end) -
Number(this._icpTransactionPayload.metadata.ingress_start); // 300s in nanoseconds
const ingressExpiries = this.getIngressExpiries(this._icpTransactionPayload.metadata.ingress_start, this._icpTransactionPayload.metadata.ingress_end, interval);
const sendArgs = this.getSendArgs(this._icpTransactionPayload.metadata.memo, this._icpTransactionPayload.metadata.created_at_time, this._icpTransactionPayload.operations[1].amount.value, this._icpTransactionPayload.operations[2].amount.value, this._icpTransactionPayload.operations[1].account.address);
const update = await this.getUpdate(sendArgs, this._icpTransactionPayload.public_keys[0].hex_bytes);
const updates = [];
updates.push([iface_1.OperationType.TRANSACTION, update]);
const txn = { updates: updates, ingress_expiries: ingressExpiries };
const unsignedTransaction = utils_1.default.cborEncode(txn);
const payloads = [];
this.getPayloads(payloads, ingressExpiries, this._icpTransactionPayload.operations[0].account.address, update);
const payloadsData = {
payloads: payloads,
unsigned_transaction: unsignedTransaction,
};
return payloadsData;
}
getPayloads(payloads, ingressExpiries, accountAddress, update) {
if (ingressExpiries.length != 1) {
throw new Error('ingress expiry can have only one entry');
}
const ingressExpiry = ingressExpiries[0];
const clonedUpdate = {
canister_id: Buffer.from(update.canister_id),
method_name: update.method_name,
arg: update.arg,
sender: update.sender,
ingress_expiry: ingressExpiry,
};
const representationIndependentHash = utils_1.default.HttpCanisterUpdateRepresentationIndependentHash(clonedUpdate);
const transactionPayload = {
hex_bytes: utils_1.default.blobToHex(utils_1.default.makeSignatureData(representationIndependentHash)),
account_identifier: { address: accountAddress },
signature_type: iface_1.SignatureType.ECDSA,
};
payloads.push(transactionPayload);
return payloads;
}
getIngressExpiries(ingressStartTime, ingressEndTime, interval) {
const ingressExpiries = [];
for (let now = Number(ingressStartTime); now < Number(ingressEndTime); now += interval) {
const ingressExpiry = BigInt(now + (iface_1.MAX_INGRESS_TTL - iface_1.PERMITTED_DRIFT));
ingressExpiries.push(ingressExpiry);
}
return ingressExpiries;
}
getSendArgs(memo, created_at_time, amount, fee, receiver) {
const sendArgs = {
payment: { receiverGets: { e8s: Number(amount) } },
maxFee: { e8s: -Number(fee) },
to: { hash: Buffer.from(receiver, 'hex') },
createdAtTime: { timestampNanos: Number(created_at_time) },
memo: { memo: memo },
};
return sendArgs;
}
async getUpdate(sendArgs, publicKeyHex) {
const principalId = utils_1.default.getPrincipalIdFromPublicKey(publicKeyHex).toUint8Array();
const senderBlob = Buffer.from(principalId);
const canisterIdBuffer = Buffer.from(iface_1.LEDGER_CANISTER_ID);
const args = await utils_1.default.toArg(sendArgs);
const update = {
canister_id: canisterIdBuffer,
method_name: iface_1.MethodName.SEND_PB,
arg: args,
sender: senderBlob,
ingress_expiry: 0n,
};
return update;
}
}
exports.UnsignedTransactionBuilder = UnsignedTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unsignedTransactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/unsignedTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  IcpTransaction,\n  SendArgs,\n  HttpCanisterUpdate,\n  SigningPayload,\n  PayloadsData,\n  SignatureType,\n  OperationType,\n  MethodName,\n  MAX_INGRESS_TTL,\n  PERMITTED_DRIFT,\n  LEDGER_CANISTER_ID,\n} from './iface';\nimport utils from './utils';\n\nexport class UnsignedTransactionBuilder {\n  private _icpTransactionPayload: IcpTransaction;\n  constructor(icpTransactionPayload: IcpTransaction) {\n    this._icpTransactionPayload = icpTransactionPayload;\n  }\n\n  async getUnsignedTransaction(): Promise<PayloadsData> {\n    // interval value can be altered here to change the count of ingressExpiries which eventually changes the number of interval value can be altered here to change the count of ingressExpiries which eventually changes the number of payloads that needs to be signed\n    const interval =\n      Number(this._icpTransactionPayload.metadata.ingress_end) -\n      Number(this._icpTransactionPayload.metadata.ingress_start); // 300s in nanoseconds\n    const ingressExpiries = this.getIngressExpiries(\n      this._icpTransactionPayload.metadata.ingress_start!,\n      this._icpTransactionPayload.metadata.ingress_end!,\n      interval\n    );\n    const sendArgs = this.getSendArgs(\n      this._icpTransactionPayload.metadata.memo,\n      this._icpTransactionPayload.metadata.created_at_time,\n      this._icpTransactionPayload.operations[1].amount.value,\n      this._icpTransactionPayload.operations[2].amount.value,\n      this._icpTransactionPayload.operations[1].account.address\n    );\n    const update = await this.getUpdate(sendArgs, this._icpTransactionPayload.public_keys[0].hex_bytes);\n    const updates: [string, HttpCanisterUpdate][] = [];\n    updates.push([OperationType.TRANSACTION, update]);\n    const txn = { updates: updates, ingress_expiries: ingressExpiries };\n    const unsignedTransaction = utils.cborEncode(txn);\n    const payloads: SigningPayload[] = [];\n    this.getPayloads(payloads, ingressExpiries, this._icpTransactionPayload.operations[0].account.address, update);\n    const payloadsData = {\n      payloads: payloads,\n      unsigned_transaction: unsignedTransaction,\n    };\n    return payloadsData;\n  }\n\n  getPayloads(\n    payloads: SigningPayload[],\n    ingressExpiries: bigint[],\n    accountAddress: string,\n    update: HttpCanisterUpdate\n  ): SigningPayload[] {\n    if (ingressExpiries.length != 1) {\n      throw new Error('ingress expiry can have only one entry');\n    }\n    const ingressExpiry = ingressExpiries[0];\n    const clonedUpdate: HttpCanisterUpdate = {\n      canister_id: Buffer.from(update.canister_id),\n      method_name: update.method_name,\n      arg: update.arg,\n      sender: update.sender,\n      ingress_expiry: ingressExpiry,\n    };\n\n    const representationIndependentHash = utils.HttpCanisterUpdateRepresentationIndependentHash(clonedUpdate);\n    const transactionPayload: SigningPayload = {\n      hex_bytes: utils.blobToHex(utils.makeSignatureData(representationIndependentHash)),\n      account_identifier: { address: accountAddress },\n      signature_type: SignatureType.ECDSA,\n    };\n    payloads.push(transactionPayload);\n    return payloads;\n  }\n\n  getIngressExpiries(ingressStartTime: number | BigInt, ingressEndTime: number | BigInt, interval: number): bigint[] {\n    const ingressExpiries: bigint[] = [];\n\n    for (let now = Number(ingressStartTime); now < Number(ingressEndTime); now += interval) {\n      const ingressExpiry = BigInt(now + (MAX_INGRESS_TTL - PERMITTED_DRIFT));\n      ingressExpiries.push(ingressExpiry);\n    }\n\n    return ingressExpiries;\n  }\n\n  getSendArgs(memo: number | BigInt, created_at_time: number, amount: string, fee: string, receiver: string): SendArgs {\n    const sendArgs: SendArgs = {\n      payment: { receiverGets: { e8s: Number(amount) } },\n      maxFee: { e8s: -Number(fee) },\n      to: { hash: Buffer.from(receiver, 'hex') },\n      createdAtTime: { timestampNanos: Number(created_at_time) },\n      memo: { memo: memo },\n    };\n\n    return sendArgs;\n  }\n\n  async getUpdate(sendArgs: SendArgs, publicKeyHex: string): Promise<HttpCanisterUpdate> {\n    const principalId = utils.getPrincipalIdFromPublicKey(publicKeyHex).toUint8Array();\n    const senderBlob = Buffer.from(principalId);\n    const canisterIdBuffer = Buffer.from(LEDGER_CANISTER_ID);\n    const args = await utils.toArg(sendArgs);\n    const update: HttpCanisterUpdate = {\n      canister_id: canisterIdBuffer,\n      method_name: MethodName.SEND_PB,\n      arg: args,\n      sender: senderBlob,\n      ingress_expiry: 0n,\n    };\n    return update;\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!