xdb-digitalbits-base
Version:
Low level digitalbits support library
72 lines (59 loc) • 2.58 kB
JavaScript
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);
}
;