@0xcert/ethereum-gateway-contracts
Version:
Smart contracts used by the gateway on the Ethereum blockchain.
425 lines • 19.2 kB
JavaScript
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const types_1 = require("@0xcert/ethereum-proxy-contracts/src/core/types");
const types_2 = require("@0xcert/ethereum-xcert-contracts/src/core/types");
const spec_1 = require("@specron/spec");
const path = require("path");
const common = require("../helpers/common");
const spec = new spec_1.Spec();
spec.before((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const accounts = yield ctx.web3.eth.getAccounts();
ctx.set('owner', accounts[0]);
ctx.set('jane', accounts[1]);
ctx.set('sara', accounts[2]);
ctx.set('zeroAddress', '0x0000000000000000000000000000000000000000');
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const jane = ctx.get('jane');
const zxc = yield ctx.deploy({
src: '@0xcert/ethereum-erc20-contracts/build/token-mock.json',
contract: 'TokenMock',
args: ['ERC20', 'ERC', 18, '300000000000000000000000000'],
from: jane,
});
ctx.set('zxc', zxc);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const deployProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/xcert-deploy-proxy.json',
contract: 'XcertDeployProxy',
});
ctx.set('deployProxy', deployProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const tokenProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/token-transfer-proxy.json',
contract: 'TokenTransferProxy',
});
ctx.set('tokenProxy', tokenProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const createProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/xcert-create-proxy.json',
contract: 'XcertCreateProxy',
});
ctx.set('createProxy', createProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const updateProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/xcert-update-proxy.json',
contract: 'XcertUpdateProxy',
});
ctx.set('updateProxy', updateProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const manageProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/abilitable-manage-proxy.json',
contract: 'AbilitableManageProxy',
});
ctx.set('manageProxy', manageProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const nftTransferProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/nftoken-safe-transfer-proxy.json',
contract: 'NFTokenSafeTransferProxy',
});
ctx.set('nftTransferProxy', nftTransferProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const burnProxy = yield ctx.deploy({
src: '@0xcert/ethereum-proxy-contracts/build/xcert-burn-proxy.json',
contract: 'XcertBurnProxy',
});
ctx.set('burnProxy', burnProxy);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const deployProxy = ctx.get('deployProxy');
const tokenProxy = ctx.get('tokenProxy');
const createProxy = ctx.get('createProxy');
const updateProxy = ctx.get('updateProxy');
const manageProxy = ctx.get('manageProxy');
const nftTransferProxy = ctx.get('nftTransferProxy');
const burnProxy = ctx.get('burnProxy');
const xcertDeployGateway = yield ctx.deploy({
src: './build/xcert-deploy-gateway.json',
contract: 'XcertDeployGateway',
args: [
deployProxy.receipt._address,
tokenProxy.receipt._address,
createProxy.receipt._address,
updateProxy.receipt._address,
manageProxy.receipt._address,
nftTransferProxy.receipt._address,
burnProxy.receipt._address,
],
});
ctx.set('xcertDeployGateway', xcertDeployGateway);
}));
spec.beforeEach((ctx) => __awaiter(void 0, void 0, void 0, function* () {
const tokenProxy = ctx.get('tokenProxy');
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const owner = ctx.get('owner');
yield tokenProxy.instance.methods.grantAbilities(xcertDeployGateway.receipt._address, types_1.TokenTransferProxyAbilities.EXECUTE).send({ from: owner });
}));
spec.test('performs a deploy', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const createProxy = ctx.get('createProxy');
const nftTransferProxy = ctx.get('nftTransferProxy');
const burnProxy = ctx.get('burnProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: zeroAddress,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
const logs = yield xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner });
ctx.not(logs.events.Perform, undefined);
const xcertAddress = logs.events.Perform.returnValues._createdContract;
const src = path.resolve(process.cwd(), 'node_modules', '@0xcert', 'ethereum-proxy-contracts', 'build', 'xcert-custom.json');
const data = require(src);
const abi = data['XcertCustom'].abi;
const xcert = new ctx.web3.eth.Contract(abi, xcertAddress);
const xcertName = yield xcert.methods.name().call();
ctx.is(xcertName, 'test');
yield xcert.methods.create(jane, '1', '0x1234567890123456789012345678901234567891').send({
from: jane,
gas: '1000000',
});
const xcert1Owner = yield xcert.methods.ownerOf('1').call();
ctx.is(xcert1Owner, jane);
const isAble = yield xcert.methods.isAble(createProxy.receipt._address, types_2.XcertAbilities.CREATE_ASSET).call();
ctx.true(isAble);
const supportsInterface = yield xcert.methods.supportsInterface('0xbedb86fb').call();
ctx.true(supportsInterface);
const ownerZxcBalance = yield zxc.instance.methods.balanceOf(owner).call();
ctx.is(ownerZxcBalance, '10000');
const nftSafeTransferProxyApproved = yield xcert.methods.isApprovedForAll(jane, nftTransferProxy.receipt._address).call();
ctx.true(nftSafeTransferProxyApproved);
const xcertBurnProxyApproved = yield xcert.methods.isApprovedForAll(jane, burnProxy.receipt._address).call();
ctx.true(xcertBurnProxyApproved);
}));
spec.test('fails when not enough balance', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 9000).send({ from: jane });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }), '001002');
}));
spec.test('fails with expired claim', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() - 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }), '009003');
}));
spec.test('fails with invalid signature', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
deployData.taker = jane;
const invalidTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(invalidTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }), '009004');
}));
spec.test('fails with invalid signature kind', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 5,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }));
}));
spec.test('fails trying to perform an already performed deploy', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
yield xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }), '009006');
}));
spec.test('fails trying to perform a canceled deploy', (ctx) => __awaiter(void 0, void 0, void 0, function* () {
const xcertDeployGateway = ctx.get('xcertDeployGateway');
const zxc = ctx.get('zxc');
const tokenProxy = ctx.get('tokenProxy');
const jane = ctx.get('jane');
const owner = ctx.get('owner');
const zeroAddress = ctx.get('zeroAddress');
const deployData = {
maker: jane,
taker: zeroAddress,
deployData: {
name: 'test',
symbol: 'TST',
uriPrefix: 'https://base.com/',
uriPostfix: '.json',
schemaId: '0x9c22ff5f21f0b81b113e63f7db6da94fedef11b2119b4088b89664fb9a3cb658',
capabilities: ['0x9d118770', '0x0d04c3b8', '0xbedb86fb', '0x20c5429b'],
owner: jane,
},
paymentData: {
token: zxc.receipt._address,
to: owner,
value: '10000',
},
seed: common.getCurrentTime(),
expirationTimestamp: common.getCurrentTime() + 3600,
};
const createTuple = ctx.tuple(deployData);
const claim = yield xcertDeployGateway.instance.methods.getDeployDataClaim(createTuple).call();
const signature = yield ctx.web3.eth.sign(claim, jane);
const signatureData = {
r: signature.substr(0, 66),
s: `0x${signature.substr(66, 64)}`,
v: parseInt(`0x${signature.substr(130, 2)}`) + 27,
kind: 0,
};
const signatureDataTuple = ctx.tuple(signatureData);
yield zxc.instance.methods.approve(tokenProxy.receipt._address, 10000).send({ from: jane });
yield xcertDeployGateway.instance.methods.cancel(createTuple).send({ from: jane });
yield ctx.reverts(() => xcertDeployGateway.instance.methods.performAnyTaker(createTuple, signatureDataTuple).send({ from: owner }), '009005');
}));
exports.default = spec;
//# sourceMappingURL=perform-any-taker-instance-method.test.js.map