UNPKG

xdb-digitalbits-base

Version:
83 lines (70 loc) 3.35 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.pathPaymentStrictReceive = pathPaymentStrictReceive; var _digitalbitsXdr_generated = require('../generated/digitalbits-xdr_generated'); var _digitalbitsXdr_generated2 = _interopRequireDefault(_digitalbitsXdr_generated); var _decode_encode_muxed_account = require('../util/decode_encode_muxed_account'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * Creates a PathPaymentStrictReceive operation. * * A `PathPaymentStrictReceive` operation sends the specified amount to the * destination account. It credits the destination with `destAmount` of * `destAsset`, while debiting at most `sendMax` of `sendAsset` from the source. * The transfer optionally occurs through a path. XDB payments create the * destination account if it does not exist. * * @function * @alias Operation.pathPaymentStrictReceive * * @param {object} opts - Options object * @param {Asset} opts.sendAsset - asset to pay with * @param {string} opts.sendMax - maximum amount of sendAsset to send * @param {string} opts.destination - destination account to send to * @param {Asset} opts.destAsset - asset the destination will receive * @param {string} opts.destAmount - amount the destination receives * @param {Asset[]} opts.path - array of Asset objects to use as the path * @param {bool} [opts.withMuxing] - Indicates that opts.destination is an * M... address and should be interpreted fully as a muxed account. By * default, this option is disabled until muxed accounts are mature. * @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.PathPaymentStrictReceiveOp) */ function pathPaymentStrictReceive(opts) { switch (true) { case !opts.sendAsset: throw new Error('Must specify a send asset'); case !this.isValidAmount(opts.sendMax): throw new TypeError(this.constructAmountRequirementsError('sendMax')); case !opts.destAsset: throw new Error('Must provide a destAsset for a payment operation'); case !this.isValidAmount(opts.destAmount): throw new TypeError(this.constructAmountRequirementsError('destAmount')); default: break; } var attributes = {}; attributes.sendAsset = opts.sendAsset.toXDRObject(); attributes.sendMax = this._toXDRAmount(opts.sendMax); try { attributes.destination = (0, _decode_encode_muxed_account.decodeAddressToMuxedAccount)(opts.destination, opts.withMuxing); } catch (e) { throw new Error('destination is invalid'); } attributes.destAsset = opts.destAsset.toXDRObject(); attributes.destAmount = this._toXDRAmount(opts.destAmount); var path = opts.path ? opts.path : []; attributes.path = path.map(function (x) { return x.toXDRObject(); }); var payment = new _digitalbitsXdr_generated2.default.PathPaymentStrictReceiveOp(attributes); var opAttributes = {}; opAttributes.body = _digitalbitsXdr_generated2.default.OperationBody.pathPaymentStrictReceive(payment); this.setSourceAccount(opAttributes, opts); return new _digitalbitsXdr_generated2.default.Operation(opAttributes); }