Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.
capabilities: deploy.assetLedgerData.capabilities.map((c) => { return getInterfaceCode(c); }),
owner: deploy.assetLedgerData.owner,
deploy.assetLedgerData.capabilities.forEach((c) => {
capabilities = capabilities + rightPad(getInterfaceCode(c), 64, '0', false);
});
capabilities: order.assetLedgerData.capabilities.map((c) => { return getInterfaceCode(c); }),
owner: order.assetLedgerData.ownerId,
.map((c) => rightPad(getInterfaceCode(c), 64, '0', false))
.join('');
export function getActionParams(action: ActionsOrderAction, signers: string[]) {
let params = '';
const signerIndex = signers.indexOf(action['senderId']);
if (signerIndex === -1) {
throw new ProviderError(ProviderIssue.WRONG_INPUT, 'SenderId not a signer.');
}
if (action.kind == ActionsOrderActionKind.CREATE_ASSET) {
params = rightPad(`0x${action['assetImprint']}`, 64);
params += leftPad(bigNumberify(action['assetId']).toHexString(), 64, '0', false);
params += action['receiverId'].substr(2);
params += leftPad(bigNumberify(signerIndex).toHexString(), 2, '0', false);
} else if (action.kind == ActionsOrderActionKind.SET_ABILITIES) {
const bitAbilities = getBitfieldFromAbilities(action.abilities);
params = leftPad(bitAbilities, 64, '0', true);
params += action['receiverId'].substr(2);
params += leftPad(bigNumberify(signerIndex).toHexString(), 2, '0', false);
} else if (action.kind == ActionsOrderActionKind.TRANSFER_ASSET) {
params = leftPad(bigNumberify(action['assetId']).toHexString(), 64, '0', true);
params += action['receiverId'].substr(2);
params += leftPad(bigNumberify(signerIndex).toHexString(), 2, '0', false);
} else if (action.kind == ActionsOrderActionKind.TRANSFER_VALUE) {
params = leftPad(bigNumberify(action['value']).toHexString(), 64, '0', true);
params += action['receiverId'].substr(2);
params += leftPad(bigNumberify(signerIndex).toHexString(), 2, '0', false);
} else if (action.kind == ActionsOrderActionKind.UPDATE_ASSET_IMPRINT) {
params = rightPad(`0x${action['assetImprint']}`, 64);
params += leftPad(bigNumberify(action['assetId']).toHexString(), 64, '0', false);
params += leftPad(bigNumberify(signerIndex).toHexString(), 2, '0', false);
} else if (action.kind == ActionsOrderActionKind.DESTROY_ASSET) {
import * as ethereum from '@0xcert/ethereum-asset-ledger';
/**
* Wanchain asset ledger implementation.
*/
export class AssetLedger extends ethereum.AssetLedger { }