Add syntactic sugar for assetDataUtils (#2388)
* add syntactic sugar for assetDataUtils
This commit is contained in:
parent
3bac6fcb27
commit
99debff5d2
@ -1,6 +1,6 @@
|
|||||||
export { getContractAddressesForChainOrThrow, ChainId, ContractAddresses } from '@0x/contract-addresses';
|
export { getContractAddressesForChainOrThrow, ChainId, ContractAddresses } from '@0x/contract-addresses';
|
||||||
|
|
||||||
export { signatureUtils, generatePseudoRandomSalt, decodeAssetDataOrThrow } from '@0x/order-utils';
|
export { signatureUtils, generatePseudoRandomSalt, assetDataUtils } from '@0x/order-utils';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
ExchangeEventArgs,
|
ExchangeEventArgs,
|
||||||
|
@ -58,6 +58,15 @@ export const docGenConfigs: DocGenConfigs = {
|
|||||||
'GlobalStakeByStatus',
|
'GlobalStakeByStatus',
|
||||||
'OwnerStakeByStatus',
|
'OwnerStakeByStatus',
|
||||||
'StakingPoolById',
|
'StakingPoolById',
|
||||||
|
'AssetData',
|
||||||
|
'SingleAssetData',
|
||||||
|
'ERC20AssetData',
|
||||||
|
'ERC20BridgeAssetData',
|
||||||
|
'ERC721AssetData',
|
||||||
|
'ERC1155AssetData',
|
||||||
|
'MultiAssetData',
|
||||||
|
'StaticCallAssetData',
|
||||||
|
'MultiAssetDataWithRecursiveDecoding',
|
||||||
],
|
],
|
||||||
// Some libraries only export types. In those cases, we cannot check if the exported types are part of the
|
// Some libraries only export types. In those cases, we cannot check if the exported types are part of the
|
||||||
// "exported public interface". Thus we add them here and skip those checks.
|
// "exported public interface". Thus we add them here and skip those checks.
|
||||||
|
@ -3,12 +3,12 @@
|
|||||||
"version": "10.0.0",
|
"version": "10.0.0",
|
||||||
"changes": [
|
"changes": [
|
||||||
{
|
{
|
||||||
"note": "Removed `assetDataUtils`",
|
"note": "Removed from assetDataUtils: individual decoding functions and assert functions",
|
||||||
"pr": 2373
|
"pr": 2388
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"note": "Exported function `decodeAssetDataOrThrow`",
|
"note": "Add ERC20Bridge support to assetDataUtils",
|
||||||
"pr": 2373
|
"pr": 2388
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
165
packages/order-utils/src/asset_data_utils.ts
Normal file
165
packages/order-utils/src/asset_data_utils.ts
Normal file
@ -0,0 +1,165 @@
|
|||||||
|
import { IAssetDataContract } from '@0x/contract-wrappers';
|
||||||
|
import {
|
||||||
|
AssetData,
|
||||||
|
AssetProxyId,
|
||||||
|
MultiAssetData,
|
||||||
|
MultiAssetDataWithRecursiveDecoding,
|
||||||
|
SingleAssetData,
|
||||||
|
} from '@0x/types';
|
||||||
|
import { BigNumber, hexUtils, NULL_ADDRESS } from '@0x/utils';
|
||||||
|
import * as _ from 'lodash';
|
||||||
|
|
||||||
|
const fakeProvider = { isEIP1193: true } as any;
|
||||||
|
const assetDataEncoder = new IAssetDataContract(NULL_ADDRESS, fakeProvider);
|
||||||
|
|
||||||
|
export const assetDataUtils = {
|
||||||
|
encodeERC20AssetData(tokenAddress: string): string {
|
||||||
|
return assetDataEncoder.ERC20Token(tokenAddress).getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
encodeERC20BridgeAssetData(tokenAddress: string, bridgeAddress: string, bridgeData: string): string {
|
||||||
|
return assetDataEncoder.ERC20Bridge(tokenAddress, bridgeAddress, bridgeData).getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
encodeERC721AssetData(tokenAddress: string, tokenId: BigNumber): string {
|
||||||
|
return assetDataEncoder.ERC721Token(tokenAddress, tokenId).getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
encodeERC1155AssetData(
|
||||||
|
tokenAddress: string,
|
||||||
|
tokenIds: BigNumber[],
|
||||||
|
tokenValues: BigNumber[],
|
||||||
|
callbackData: string,
|
||||||
|
): string {
|
||||||
|
return assetDataEncoder
|
||||||
|
.ERC1155Assets(tokenAddress, tokenIds, tokenValues, callbackData)
|
||||||
|
.getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
encodeMultiAssetData(values: BigNumber[], nestedAssetData: string[]): string {
|
||||||
|
return assetDataEncoder.MultiAsset(values, nestedAssetData).getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
encodeStaticCallAssetData(
|
||||||
|
staticCallTargetAddress: string,
|
||||||
|
staticCallData: string,
|
||||||
|
expectedReturnDataHash: string,
|
||||||
|
): string {
|
||||||
|
return assetDataEncoder
|
||||||
|
.StaticCall(staticCallTargetAddress, staticCallData, expectedReturnDataHash)
|
||||||
|
.getABIEncodedTransactionData();
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Decode any assetData into its corresponding assetData object
|
||||||
|
* @param assetData Hex encoded assetData string to decode
|
||||||
|
* @return Either a ERC20, ERC20Bridge, ERC721, ERC1155, StaticCall, or MultiAsset assetData object
|
||||||
|
*/
|
||||||
|
decodeAssetDataOrThrow(assetData: string): AssetData {
|
||||||
|
const assetProxyId = hexUtils.slice(assetData, 0, 4); // tslint:disable-line:custom-no-magic-numbers
|
||||||
|
switch (assetProxyId) {
|
||||||
|
case AssetProxyId.ERC20: {
|
||||||
|
const tokenAddress = assetDataEncoder.getABIDecodedTransactionData<string>('ERC20Token', assetData);
|
||||||
|
return {
|
||||||
|
assetProxyId,
|
||||||
|
tokenAddress,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
case AssetProxyId.ERC20Bridge: {
|
||||||
|
const [tokenAddress, bridgeAddress, bridgeData] = assetDataEncoder.getABIDecodedTransactionData<
|
||||||
|
[string, string, string]
|
||||||
|
>('ERC20Bridge', assetData);
|
||||||
|
return {
|
||||||
|
assetProxyId,
|
||||||
|
tokenAddress,
|
||||||
|
bridgeAddress,
|
||||||
|
bridgeData,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
case AssetProxyId.ERC721: {
|
||||||
|
const [tokenAddress, tokenId] = assetDataEncoder.getABIDecodedTransactionData<[string, BigNumber]>(
|
||||||
|
'ERC721Token',
|
||||||
|
assetData,
|
||||||
|
);
|
||||||
|
return {
|
||||||
|
assetProxyId,
|
||||||
|
tokenAddress,
|
||||||
|
tokenId,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
case AssetProxyId.ERC1155: {
|
||||||
|
const [
|
||||||
|
tokenAddress,
|
||||||
|
tokenIds,
|
||||||
|
tokenValues,
|
||||||
|
callbackData,
|
||||||
|
] = assetDataEncoder.getABIDecodedTransactionData<[string, BigNumber[], BigNumber[], string]>(
|
||||||
|
'ERC1155Assets',
|
||||||
|
assetData,
|
||||||
|
);
|
||||||
|
return {
|
||||||
|
assetProxyId,
|
||||||
|
tokenAddress,
|
||||||
|
tokenIds,
|
||||||
|
tokenValues,
|
||||||
|
callbackData,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
case AssetProxyId.MultiAsset: {
|
||||||
|
const [amounts, nestedAssetData] = assetDataEncoder.getABIDecodedTransactionData<
|
||||||
|
[BigNumber[], string[]]
|
||||||
|
>('MultiAsset', assetData);
|
||||||
|
|
||||||
|
const multiAssetData: MultiAssetData = {
|
||||||
|
assetProxyId,
|
||||||
|
amounts,
|
||||||
|
nestedAssetData,
|
||||||
|
};
|
||||||
|
return multiAssetData;
|
||||||
|
}
|
||||||
|
case AssetProxyId.StaticCall:
|
||||||
|
const [callTarget, staticCallData, callResultHash] = assetDataEncoder.getABIDecodedTransactionData<
|
||||||
|
[string, string, string]
|
||||||
|
>('StaticCall', assetData);
|
||||||
|
return {
|
||||||
|
assetProxyId,
|
||||||
|
callTarget,
|
||||||
|
staticCallData,
|
||||||
|
callResultHash,
|
||||||
|
};
|
||||||
|
default:
|
||||||
|
throw new Error(`Unhandled asset proxy ID: ${assetProxyId}`);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Decodes a MultiAsset assetData hex string into its corresponding amounts and decoded nestedAssetData elements (all nested elements are flattened)
|
||||||
|
* @param assetData Hex encoded assetData string to decode
|
||||||
|
* @return An object containing the decoded amounts and nestedAssetData
|
||||||
|
*/
|
||||||
|
decodeMultiAssetDataRecursively(assetData: string): MultiAssetDataWithRecursiveDecoding {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeAssetDataOrThrow(assetData) as MultiAssetData; // tslint:disable-line:no-unnecessary-type-assertion
|
||||||
|
if (decodedAssetData.assetProxyId !== AssetProxyId.MultiAsset) {
|
||||||
|
throw new Error(`Not a MultiAssetData. Use 'decodeAssetDataOrThrow' instead`);
|
||||||
|
}
|
||||||
|
const amounts: any[] = [];
|
||||||
|
const decodedNestedAssetData = decodedAssetData.nestedAssetData.map((nestedAssetDataElement, index) => {
|
||||||
|
const decodedNestedAssetDataElement = assetDataUtils.decodeAssetDataOrThrow(nestedAssetDataElement);
|
||||||
|
if (decodedNestedAssetDataElement.assetProxyId === AssetProxyId.MultiAsset) {
|
||||||
|
const recursivelyDecodedAssetData = assetDataUtils.decodeMultiAssetDataRecursively(
|
||||||
|
nestedAssetDataElement,
|
||||||
|
);
|
||||||
|
amounts.push(
|
||||||
|
recursivelyDecodedAssetData.amounts.map(amountElement =>
|
||||||
|
amountElement.times(decodedAssetData.amounts[index]),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
return recursivelyDecodedAssetData.nestedAssetData;
|
||||||
|
} else {
|
||||||
|
amounts.push(decodedAssetData.amounts[index]);
|
||||||
|
return decodedNestedAssetDataElement;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
const flattenedAmounts = _.flattenDeep(amounts);
|
||||||
|
const flattenedDecodedNestedAssetData = _.flattenDeep(decodedNestedAssetData);
|
||||||
|
return {
|
||||||
|
assetProxyId: decodedAssetData.assetProxyId,
|
||||||
|
amounts: flattenedAmounts,
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
nestedAssetData: flattenedDecodedNestedAssetData as SingleAssetData[],
|
||||||
|
};
|
||||||
|
},
|
||||||
|
};
|
@ -1,80 +0,0 @@
|
|||||||
import { IAssetDataContract } from '@0x/contract-wrappers';
|
|
||||||
import { AssetData, AssetProxyId } from '@0x/types';
|
|
||||||
import { BigNumber, hexUtils, NULL_ADDRESS } from '@0x/utils';
|
|
||||||
|
|
||||||
const fakeProvider = { isEIP1193: true } as any;
|
|
||||||
const assetDataDecoder = new IAssetDataContract(NULL_ADDRESS, fakeProvider);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Decode any assetData into its corresponding assetData object
|
|
||||||
* @param assetData Hex encoded assetData string to decode
|
|
||||||
* @return Either a ERC20, ERC20Bridge, ERC721, ERC1155, StaticCall, or MultiAsset assetData object
|
|
||||||
*/
|
|
||||||
export function decodeAssetDataOrThrow(assetData: string): AssetData {
|
|
||||||
const assetProxyId = hexUtils.slice(assetData, 0, 4); // tslint:disable-line:custom-no-magic-numbers
|
|
||||||
switch (assetProxyId) {
|
|
||||||
case AssetProxyId.ERC20: {
|
|
||||||
const tokenAddress = assetDataDecoder.getABIDecodedTransactionData<string>('ERC20Token', assetData);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
tokenAddress,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case AssetProxyId.ERC20Bridge: {
|
|
||||||
const [tokenAddress, bridgeAddress, bridgeData] = assetDataDecoder.getABIDecodedTransactionData<
|
|
||||||
[string, string, string]
|
|
||||||
>('ERC20Bridge', assetData);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
tokenAddress,
|
|
||||||
bridgeAddress,
|
|
||||||
bridgeData,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case AssetProxyId.ERC721: {
|
|
||||||
const [tokenAddress, tokenId] = assetDataDecoder.getABIDecodedTransactionData<[string, BigNumber]>(
|
|
||||||
'ERC721Token',
|
|
||||||
assetData,
|
|
||||||
);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
tokenAddress,
|
|
||||||
tokenId,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case AssetProxyId.ERC1155: {
|
|
||||||
const [tokenAddress, tokenIds, tokenValues] = assetDataDecoder.getABIDecodedTransactionData<
|
|
||||||
[string, BigNumber[], BigNumber[]]
|
|
||||||
>('ERC1155Assets', assetData);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
tokenAddress,
|
|
||||||
tokenIds,
|
|
||||||
tokenValues,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case AssetProxyId.MultiAsset: {
|
|
||||||
const [amounts, nestedAssetData] = assetDataDecoder.getABIDecodedTransactionData<[BigNumber[], string[]]>(
|
|
||||||
'MultiAsset',
|
|
||||||
assetData,
|
|
||||||
);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
amounts,
|
|
||||||
nestedAssetData,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
case AssetProxyId.StaticCall:
|
|
||||||
const [callTarget, staticCallData, callResultHash] = assetDataDecoder.getABIDecodedTransactionData<
|
|
||||||
[string, string, string]
|
|
||||||
>('StaticCall', assetData);
|
|
||||||
return {
|
|
||||||
assetProxyId,
|
|
||||||
callTarget,
|
|
||||||
staticCallData,
|
|
||||||
callResultHash,
|
|
||||||
};
|
|
||||||
default:
|
|
||||||
throw new Error(`Unhandled asset proxy ID: ${assetProxyId}`);
|
|
||||||
}
|
|
||||||
}
|
|
@ -5,7 +5,7 @@ export { rateUtils } from './rate_utils';
|
|||||||
export { sortingUtils } from './sorting_utils';
|
export { sortingUtils } from './sorting_utils';
|
||||||
export { orderCalculationUtils } from './order_calculation_utils';
|
export { orderCalculationUtils } from './order_calculation_utils';
|
||||||
export { orderHashUtils } from './order_hash_utils';
|
export { orderHashUtils } from './order_hash_utils';
|
||||||
export { decodeAssetDataOrThrow } from './decode_asset_data';
|
export { assetDataUtils } from './asset_data_utils';
|
||||||
|
|
||||||
export { eip712Utils } from './eip712_utils';
|
export { eip712Utils } from './eip712_utils';
|
||||||
|
|
||||||
|
186
packages/order-utils/test/asset_data_utils_test.ts
Normal file
186
packages/order-utils/test/asset_data_utils_test.ts
Normal file
@ -0,0 +1,186 @@
|
|||||||
|
import * as chai from 'chai';
|
||||||
|
|
||||||
|
import { AssetProxyId, ERC1155AssetData, ERC20AssetData, ERC721AssetData, MultiAssetData } from '@0x/types';
|
||||||
|
import { BigNumber } from '@0x/utils';
|
||||||
|
|
||||||
|
import { assetDataUtils } from '../src/asset_data_utils';
|
||||||
|
|
||||||
|
import { chaiSetup } from './utils/chai_setup';
|
||||||
|
|
||||||
|
chaiSetup.configure();
|
||||||
|
const expect = chai.expect;
|
||||||
|
|
||||||
|
const KNOWN_ERC20_ENCODING = {
|
||||||
|
address: '0x1dc4c1cefef38a777b15aa20260a54e584b16c48',
|
||||||
|
assetData: '0xf47261b00000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c48',
|
||||||
|
};
|
||||||
|
const KNOWN_ERC721_ENCODING = {
|
||||||
|
address: '0x1dc4c1cefef38a777b15aa20260a54e584b16c48',
|
||||||
|
tokenId: new BigNumber(1),
|
||||||
|
assetData:
|
||||||
|
'0x025717920000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c480000000000000000000000000000000000000000000000000000000000000001',
|
||||||
|
};
|
||||||
|
const KNOWN_ERC1155_ENCODING = {
|
||||||
|
tokenAddress: '0x1dc4c1cefef38a777b15aa20260a54e584b16c48',
|
||||||
|
tokenIds: [new BigNumber(100), new BigNumber(1001), new BigNumber(10001)],
|
||||||
|
tokenValues: [new BigNumber(200), new BigNumber(2001), new BigNumber(20001)],
|
||||||
|
callbackData:
|
||||||
|
'0x025717920000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c480000000000000000000000000000000000000000000000000000000000000001',
|
||||||
|
assetData:
|
||||||
|
'0xa7cb5fb70000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c480000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001800000000000000000000000000000000000000000000000000000000000000003000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000003e90000000000000000000000000000000000000000000000000000000000002711000000000000000000000000000000000000000000000000000000000000000300000000000000000000000000000000000000000000000000000000000000c800000000000000000000000000000000000000000000000000000000000007d10000000000000000000000000000000000000000000000000000000000004e210000000000000000000000000000000000000000000000000000000000000044025717920000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c48000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000',
|
||||||
|
};
|
||||||
|
const KNOWN_MULTI_ASSET_ENCODING = {
|
||||||
|
amounts: [new BigNumber(70), new BigNumber(1), new BigNumber(18)],
|
||||||
|
nestedAssetData: [
|
||||||
|
KNOWN_ERC20_ENCODING.assetData,
|
||||||
|
KNOWN_ERC721_ENCODING.assetData,
|
||||||
|
KNOWN_ERC1155_ENCODING.assetData,
|
||||||
|
],
|
||||||
|
assetData:
|
||||||
|
'0x94cfcdd7000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000000030000000000000000000000000000000000000000000000000000000000000046000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000120000000000000000000000000000000000000000000000000000000000000003000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000c000000000000000000000000000000000000000000000000000000000000001400000000000000000000000000000000000000000000000000000000000000024f47261b00000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c48000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000044025717920000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c480000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000204a7cb5fb70000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c480000000000000000000000000000000000000000000000000000000000000080000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001800000000000000000000000000000000000000000000000000000000000000003000000000000000000000000000000000000000000000000000000000000006400000000000000000000000000000000000000000000000000000000000003e90000000000000000000000000000000000000000000000000000000000002711000000000000000000000000000000000000000000000000000000000000000300000000000000000000000000000000000000000000000000000000000000c800000000000000000000000000000000000000000000000000000000000007d10000000000000000000000000000000000000000000000000000000000004e210000000000000000000000000000000000000000000000000000000000000044025717920000000000000000000000001dc4c1cefef38a777b15aa20260a54e584b16c4800000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
||||||
|
};
|
||||||
|
|
||||||
|
describe('assetDataUtils', () => {
|
||||||
|
it('should encode ERC20', () => {
|
||||||
|
const assetData = assetDataUtils.encodeERC20AssetData(KNOWN_ERC20_ENCODING.address);
|
||||||
|
expect(assetData).to.equal(KNOWN_ERC20_ENCODING.assetData);
|
||||||
|
});
|
||||||
|
it('should decode ERC20', () => {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeAssetDataOrThrow(
|
||||||
|
KNOWN_ERC20_ENCODING.assetData,
|
||||||
|
) as ERC20AssetData; // tslint:disable-line:no-unnecessary-type-assertion
|
||||||
|
expect(decodedAssetData.tokenAddress).to.equal(KNOWN_ERC20_ENCODING.address);
|
||||||
|
expect(decodedAssetData.assetProxyId).to.equal(AssetProxyId.ERC20);
|
||||||
|
});
|
||||||
|
it('should encode ERC721', () => {
|
||||||
|
const assetData = assetDataUtils.encodeERC721AssetData(
|
||||||
|
KNOWN_ERC721_ENCODING.address,
|
||||||
|
KNOWN_ERC721_ENCODING.tokenId,
|
||||||
|
);
|
||||||
|
expect(assetData).to.equal(KNOWN_ERC721_ENCODING.assetData);
|
||||||
|
});
|
||||||
|
it('should decode ERC721', () => {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeAssetDataOrThrow(
|
||||||
|
KNOWN_ERC721_ENCODING.assetData,
|
||||||
|
) as ERC721AssetData; // tslint:disable-line:no-unnecessary-type-assertion
|
||||||
|
expect(decodedAssetData.tokenAddress).to.equal(KNOWN_ERC721_ENCODING.address);
|
||||||
|
expect(decodedAssetData.assetProxyId).to.equal(AssetProxyId.ERC721);
|
||||||
|
expect(decodedAssetData.tokenId).to.be.bignumber.equal(KNOWN_ERC721_ENCODING.tokenId);
|
||||||
|
});
|
||||||
|
it('should encode ERC1155', () => {
|
||||||
|
const assetData = assetDataUtils.encodeERC1155AssetData(
|
||||||
|
KNOWN_ERC1155_ENCODING.tokenAddress,
|
||||||
|
KNOWN_ERC1155_ENCODING.tokenIds,
|
||||||
|
KNOWN_ERC1155_ENCODING.tokenValues,
|
||||||
|
KNOWN_ERC1155_ENCODING.callbackData,
|
||||||
|
);
|
||||||
|
expect(assetData).to.equal(KNOWN_ERC1155_ENCODING.assetData);
|
||||||
|
});
|
||||||
|
it('should decode ERC1155', () => {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeAssetDataOrThrow(
|
||||||
|
KNOWN_ERC1155_ENCODING.assetData,
|
||||||
|
) as ERC1155AssetData; // tslint:disable-line:no-unnecessary-type-assertion
|
||||||
|
expect(decodedAssetData.assetProxyId).to.be.equal(AssetProxyId.ERC1155);
|
||||||
|
expect(decodedAssetData.tokenAddress).to.be.equal(KNOWN_ERC1155_ENCODING.tokenAddress);
|
||||||
|
expect(decodedAssetData.tokenValues).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenValues);
|
||||||
|
expect(decodedAssetData.tokenIds).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenIds);
|
||||||
|
expect(decodedAssetData.callbackData).to.be.equal(KNOWN_ERC1155_ENCODING.callbackData);
|
||||||
|
});
|
||||||
|
it('should encode ERC20, ERC721 and ERC1155 multiAssetData', () => {
|
||||||
|
const assetData = assetDataUtils.encodeMultiAssetData(
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.amounts,
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.nestedAssetData,
|
||||||
|
);
|
||||||
|
expect(assetData).to.equal(KNOWN_MULTI_ASSET_ENCODING.assetData);
|
||||||
|
});
|
||||||
|
it('should decode ERC20, ERC721 and ERC1155 multiAssetData', () => {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeAssetDataOrThrow(
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.assetData,
|
||||||
|
) as MultiAssetData; // tslint:disable-line:no-unnecessary-type-assertion
|
||||||
|
expect(decodedAssetData.assetProxyId).to.equal(AssetProxyId.MultiAsset);
|
||||||
|
expect(decodedAssetData.amounts).to.deep.equal(KNOWN_MULTI_ASSET_ENCODING.amounts);
|
||||||
|
expect(decodedAssetData.nestedAssetData).to.deep.equal(KNOWN_MULTI_ASSET_ENCODING.nestedAssetData);
|
||||||
|
});
|
||||||
|
it('should recursively decode ERC20 and ERC721 multiAssetData', () => {
|
||||||
|
const decodedAssetData = assetDataUtils.decodeMultiAssetDataRecursively(KNOWN_MULTI_ASSET_ENCODING.assetData);
|
||||||
|
expect(decodedAssetData.assetProxyId).to.equal(AssetProxyId.MultiAsset);
|
||||||
|
expect(decodedAssetData.amounts).to.deep.equal(KNOWN_MULTI_ASSET_ENCODING.amounts);
|
||||||
|
expect(decodedAssetData.nestedAssetData.length).to.equal(3);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc20AssetData = decodedAssetData.nestedAssetData[0] as ERC20AssetData;
|
||||||
|
expect(decodedErc20AssetData.tokenAddress).to.equal(KNOWN_ERC20_ENCODING.address);
|
||||||
|
expect(decodedErc20AssetData.assetProxyId).to.equal(AssetProxyId.ERC20);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc721AssetData = decodedAssetData.nestedAssetData[1] as ERC721AssetData;
|
||||||
|
expect(decodedErc721AssetData.tokenAddress).to.equal(KNOWN_ERC721_ENCODING.address);
|
||||||
|
expect(decodedErc721AssetData.assetProxyId).to.equal(AssetProxyId.ERC721);
|
||||||
|
expect(decodedErc721AssetData.tokenId).to.be.bignumber.equal(KNOWN_ERC721_ENCODING.tokenId);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc1155AssetData = decodedAssetData.nestedAssetData[2] as ERC1155AssetData;
|
||||||
|
expect(decodedErc1155AssetData.tokenAddress).to.be.equal(KNOWN_ERC1155_ENCODING.tokenAddress);
|
||||||
|
expect(decodedErc1155AssetData.tokenValues).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenValues);
|
||||||
|
expect(decodedErc1155AssetData.tokenIds).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenIds);
|
||||||
|
expect(decodedErc1155AssetData.callbackData).to.be.equal(KNOWN_ERC1155_ENCODING.callbackData);
|
||||||
|
});
|
||||||
|
it('should recursively decode nested assetData within multiAssetData', () => {
|
||||||
|
// setup test parameters
|
||||||
|
const erc20Amount = new BigNumber(1);
|
||||||
|
const erc721Amount = new BigNumber(1);
|
||||||
|
const erc1155Amount = new BigNumber(15);
|
||||||
|
const nestedAssetsAmount = new BigNumber(2);
|
||||||
|
const amounts = [erc20Amount, erc721Amount, erc1155Amount, nestedAssetsAmount];
|
||||||
|
const nestedAssetData = [
|
||||||
|
KNOWN_ERC20_ENCODING.assetData,
|
||||||
|
KNOWN_ERC721_ENCODING.assetData,
|
||||||
|
KNOWN_ERC1155_ENCODING.assetData,
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.assetData,
|
||||||
|
];
|
||||||
|
const assetData = assetDataUtils.encodeMultiAssetData(amounts, nestedAssetData);
|
||||||
|
// execute test
|
||||||
|
const decodedAssetData = assetDataUtils.decodeMultiAssetDataRecursively(assetData);
|
||||||
|
// validate asset data
|
||||||
|
expect(decodedAssetData.assetProxyId).to.equal(AssetProxyId.MultiAsset);
|
||||||
|
const expectedAmounts = [
|
||||||
|
erc20Amount,
|
||||||
|
erc721Amount,
|
||||||
|
erc1155Amount,
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.amounts[0].times(nestedAssetsAmount),
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.amounts[1].times(nestedAssetsAmount),
|
||||||
|
KNOWN_MULTI_ASSET_ENCODING.amounts[2].times(nestedAssetsAmount),
|
||||||
|
];
|
||||||
|
expect(decodedAssetData.amounts).to.deep.equal(expectedAmounts);
|
||||||
|
const expectedNestedAssetDataLength = 6;
|
||||||
|
expect(decodedAssetData.nestedAssetData.length).to.be.equal(expectedNestedAssetDataLength);
|
||||||
|
// validate nested asset data (outer)
|
||||||
|
let nestedAssetDataIndex = 0;
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc20AssetData1 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC20AssetData;
|
||||||
|
expect(decodedErc20AssetData1.tokenAddress).to.equal(KNOWN_ERC20_ENCODING.address);
|
||||||
|
expect(decodedErc20AssetData1.assetProxyId).to.equal(AssetProxyId.ERC20);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc721AssetData1 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC721AssetData;
|
||||||
|
expect(decodedErc721AssetData1.tokenAddress).to.equal(KNOWN_ERC721_ENCODING.address);
|
||||||
|
expect(decodedErc721AssetData1.assetProxyId).to.equal(AssetProxyId.ERC721);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc1155AssetData1 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC1155AssetData;
|
||||||
|
expect(decodedErc1155AssetData1.tokenAddress).to.be.equal(KNOWN_ERC1155_ENCODING.tokenAddress);
|
||||||
|
expect(decodedErc1155AssetData1.tokenValues).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenValues);
|
||||||
|
expect(decodedErc1155AssetData1.tokenIds).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenIds);
|
||||||
|
expect(decodedErc1155AssetData1.callbackData).to.be.equal(KNOWN_ERC1155_ENCODING.callbackData);
|
||||||
|
// validate nested asset data (inner)
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc20AssetData2 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC20AssetData;
|
||||||
|
expect(decodedErc20AssetData2.tokenAddress).to.equal(KNOWN_ERC20_ENCODING.address);
|
||||||
|
expect(decodedErc20AssetData2.assetProxyId).to.equal(AssetProxyId.ERC20);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc721AssetData2 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC721AssetData;
|
||||||
|
expect(decodedErc721AssetData2.tokenAddress).to.equal(KNOWN_ERC721_ENCODING.address);
|
||||||
|
expect(decodedErc721AssetData2.assetProxyId).to.equal(AssetProxyId.ERC721);
|
||||||
|
// tslint:disable-next-line:no-unnecessary-type-assertion
|
||||||
|
const decodedErc1155AssetData2 = decodedAssetData.nestedAssetData[nestedAssetDataIndex++] as ERC1155AssetData;
|
||||||
|
expect(decodedErc1155AssetData2.tokenAddress).to.be.equal(KNOWN_ERC1155_ENCODING.tokenAddress);
|
||||||
|
expect(decodedErc1155AssetData2.tokenValues).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenValues);
|
||||||
|
expect(decodedErc1155AssetData2.tokenIds).to.be.deep.equal(KNOWN_ERC1155_ENCODING.tokenIds);
|
||||||
|
expect(decodedErc1155AssetData2.callbackData).to.be.equal(KNOWN_ERC1155_ENCODING.callbackData);
|
||||||
|
});
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user