xdb-digitalbits-base
Version:
Low level digitalbits support library
51 lines (41 loc) • 1.95 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.claimClaimableBalance = claimClaimableBalance;
exports.validateClaimableBalanceId = validateClaimableBalanceId;
var _digitalbitsXdr_generated = require('../generated/digitalbits-xdr_generated');
var _digitalbitsXdr_generated2 = _interopRequireDefault(_digitalbitsXdr_generated);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/**
* Create a new claim claimable balance operation.
* @function
* @alias Operation.claimClaimableBalance
* @param {object} opts Options object
* @param {string} opts.balanceId - The claimable balance id to be claimed.
* @param {string} [opts.source] - The source account for the operation. Defaults to the transaction's source account.
* @returns {xdr.Operation} Claim claimable balance operation
*
* @example
* const op = Operation.claimClaimableBalance({
* balanceId: '00000000da0d57da7d4850e7fc10d2a9d0ebc731f7afb40574c03395b17d49149b91f5be',
* });
*
*/
function claimClaimableBalance() {
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
validateClaimableBalanceId(opts.balanceId);
var attributes = {};
attributes.balanceId = _digitalbitsXdr_generated2.default.ClaimableBalanceId.fromXDR(opts.balanceId, 'hex');
var claimClaimableBalanceOp = new _digitalbitsXdr_generated2.default.ClaimClaimableBalanceOp(attributes);
var opAttributes = {};
opAttributes.body = _digitalbitsXdr_generated2.default.OperationBody.claimClaimableBalance(claimClaimableBalanceOp);
this.setSourceAccount(opAttributes, opts);
return new _digitalbitsXdr_generated2.default.Operation(opAttributes);
}
function validateClaimableBalanceId(balanceId) {
if (typeof balanceId !== 'string' || balanceId.length !== 8 + 64 /* 8b discriminant + 64b string */
) {
throw new Error('must provide a valid claimable balance id');
}
}
;