本文整理汇总了TypeScript中stellar-sdk.Operation.payment方法的典型用法代码示例。如果您正苦于以下问题:TypeScript Operation.payment方法的具体用法?TypeScript Operation.payment怎么用?TypeScript Operation.payment使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类stellar-sdk.Operation
的用法示例。
在下文中一共展示了Operation.payment方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: co
return co(function *() {
const [userKey, backupKey] = this.initiateRecovery(params);
const isKrsRecovery = params.backupKey.startsWith('G') && !params.userKey.startsWith('G');
const isUnsignedSweep = params.backupKey.startsWith('G') && params.userKey.startsWith('G');
if (!stellar.StrKey.isValidEd25519PublicKey(params.rootAddress)) {
throw new Error(`Invalid wallet address: ${ params.rootAddress }`);
}
const accountDataUrl = `${ this.getHorizonUrl() }/accounts/${ params.rootAddress }`;
const destinationUrl = `${ this.getHorizonUrl() }/accounts/${ params.recoveryDestination }`;
let accountData;
try {
accountData = yield request.get(accountDataUrl).result();
} catch (e) {
throw new Error('Unable to reach the Stellar network via Horizon.');
}
// Now check if the destination account is empty or not
let unfundedDestination = false;
try {
yield request.get(destinationUrl);
} catch (e) {
if (e.status === 404) {
// If the destination account does not yet exist, horizon responds with 404
unfundedDestination = true;
}
}
if (!accountData.sequence || !accountData.balances) {
throw new Error('Horizon server error - unable to retrieve sequence ID or account balance');
}
const account = new stellar.Account(params.rootAddress, accountData.sequence);
// Stellar supports multiple assets on chain, we're only interested in the balances entry whose type is "native" (XLM)
const nativeBalanceInfo = accountData.balances.find(assetBalance => assetBalance['asset_type'] === 'native');
if (!nativeBalanceInfo) {
throw new Error('Provided wallet has a balance of 0 XLM, recovery aborted');
}
const walletBalance = this.bigUnitsToBaseUnits(nativeBalanceInfo.balance);
const minimumReserve = yield this.getMinimumReserve();
const baseTxFee = yield this.getBaseTransactionFee();
const recoveryAmount = walletBalance - minimumReserve - baseTxFee;
const formattedRecoveryAmount = (this.baseUnitsToBigUnits(recoveryAmount)).toString();
let txBuilder = new stellar.TransactionBuilder(account);
let operation;
if (unfundedDestination) { // In this case, we need to create the account
operation = stellar.Operation.createAccount({
destination: params.recoveryDestination,
startingBalance: formattedRecoveryAmount
});
} else { // Otherwise if the account already exists, we do a normal send
operation = stellar.Operation.payment({
destination: params.recoveryDestination,
asset: stellar.Asset.native(),
amount: formattedRecoveryAmount
});
}
txBuilder = txBuilder.addOperation(operation).build();
if (!isUnsignedSweep) {
txBuilder.sign(userKey);
}
if (!isKrsRecovery && !isUnsignedSweep) {
txBuilder.sign(backupKey);
}
const transaction: any = {
tx: txBuilder.toEnvelope().toXDR('base64'),
recoveryAmount
};
if (isKrsRecovery) {
transaction.backupKey = params.backupKey;
transaction.coin = this.getChain();
}
return transaction;
}).call(this);