UNPKG

xdb-digitalbits-base

Version:
72 lines (59 loc) 2.58 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.allowTrust = allowTrust; var _padEnd = require('lodash/padEnd'); var _padEnd2 = _interopRequireDefault(_padEnd); var _digitalbitsXdr_generated = require('../generated/digitalbits-xdr_generated'); var _digitalbitsXdr_generated2 = _interopRequireDefault(_digitalbitsXdr_generated); var _keypair = require('../keypair'); var _strkey = require('../strkey'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * @deprecated since v5.0 * * Returns an XDR AllowTrustOp. An "allow trust" operation authorizes another * account to hold your account's credit for a given asset. * * @function * @alias Operation.allowTrust * * @param {object} opts Options object * @param {string} opts.trustor - The trusting account (the one being authorized) * @param {string} opts.assetCode - The asset code being authorized. * @param {(0|1|2)} opts.authorize - `1` to authorize, `2` to authorize to maintain liabilities, and `0` to deauthorize. * @param {string} [opts.source] - The source account (defaults to transaction source). * * @returns {xdr.AllowTrustOp} Allow Trust operation */ function allowTrust(opts) { if (!_strkey.StrKey.isValidEd25519PublicKey(opts.trustor)) { throw new Error('trustor is invalid'); } var attributes = {}; attributes.trustor = _keypair.Keypair.fromPublicKey(opts.trustor).xdrAccountId(); if (opts.assetCode.length <= 4) { var code = (0, _padEnd2.default)(opts.assetCode, 4, '\0'); attributes.asset = _digitalbitsXdr_generated2.default.AssetCode.assetTypeCreditAlphanum4(code); } else if (opts.assetCode.length <= 12) { var _code = (0, _padEnd2.default)(opts.assetCode, 12, '\0'); attributes.asset = _digitalbitsXdr_generated2.default.AssetCode.assetTypeCreditAlphanum12(_code); } else { throw new Error('Asset code must be 12 characters at max.'); } if (typeof opts.authorize === 'boolean') { if (opts.authorize) { attributes.authorize = _digitalbitsXdr_generated2.default.TrustLineFlags.authorizedFlag().value; } else { attributes.authorize = 0; } } else { attributes.authorize = opts.authorize; } var allowTrustOp = new _digitalbitsXdr_generated2.default.AllowTrustOp(attributes); var opAttributes = {}; opAttributes.body = _digitalbitsXdr_generated2.default.OperationBody.allowTrust(allowTrustOp); this.setSourceAccount(opAttributes, opts); return new _digitalbitsXdr_generated2.default.Operation(opAttributes); }