UNPKG

diamante-base

Version:

Low-level support library for the Diamante network.

68 lines (67 loc) 2.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.pathPaymentStrictSend = pathPaymentStrictSend; var _xdr = _interopRequireDefault(require("../xdr")); var _decode_encode_muxed_account = require("../util/decode_encode_muxed_account"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } /** * Creates a PathPaymentStrictSend operation. * * A `PathPaymentStrictSend` operation sends the specified amount to the * destination account crediting at least `destMin` of `destAsset`, optionally * through a path. XLM payments create the destination account if it does not * exist. * * @function * @alias Operation.pathPaymentStrictSend * @see https://developers.diamante.org/docs/start/list-of-operations/#path-payment-strict-send * * @param {object} opts - Options object * @param {Asset} opts.sendAsset - asset to pay with * @param {string} opts.sendAmount - amount of sendAsset to send (excluding fees) * @param {string} opts.destination - destination account to send to * @param {Asset} opts.destAsset - asset the destination will receive * @param {string} opts.destMin - minimum amount of destAsset to be receive * @param {Asset[]} opts.path - array of Asset objects to use as the path * * @param {string} [opts.source] - The source account for the payment. * Defaults to the transaction's source account. * * @returns {xdr.Operation} the resulting path payment operation * (xdr.PathPaymentStrictSendOp) */ function pathPaymentStrictSend(opts) { switch (true) { case !opts.sendAsset: throw new Error('Must specify a send asset'); case !this.isValidAmount(opts.sendAmount): throw new TypeError(this.constructAmountRequirementsError('sendAmount')); case !opts.destAsset: throw new Error('Must provide a destAsset for a payment operation'); case !this.isValidAmount(opts.destMin): throw new TypeError(this.constructAmountRequirementsError('destMin')); default: break; } var attributes = {}; attributes.sendAsset = opts.sendAsset.toXDRObject(); attributes.sendAmount = this._toXDRAmount(opts.sendAmount); try { attributes.destination = (0, _decode_encode_muxed_account.decodeAddressToMuxedAccount)(opts.destination); } catch (e) { throw new Error('destination is invalid'); } attributes.destAsset = opts.destAsset.toXDRObject(); attributes.destMin = this._toXDRAmount(opts.destMin); var path = opts.path ? opts.path : []; attributes.path = path.map(function (x) { return x.toXDRObject(); }); var payment = new _xdr["default"].PathPaymentStrictSendOp(attributes); var opAttributes = {}; opAttributes.body = _xdr["default"].OperationBody.pathPaymentStrictSend(payment); this.setSourceAccount(opAttributes, opts); return new _xdr["default"].Operation(opAttributes); }