mirror of https://github.com/embarklabs/embark.git
feat(@embark/contracts): add proxyFor property for contracts
Requested here https://github.com/embarklabs/embark/issues/1689 Adds proxyFor to contracts that merges the ABI of the parent contract to the child (proxy) contract so that the proxy can use the methods of the parent but is deployed as itself
This commit is contained in:
parent
414de52203
commit
2e8b2554df
|
@ -338,7 +338,7 @@ export default class ContractsManager {
|
||||||
|
|
||||||
if (contract.address && typeof contract.address === 'function') {
|
if (contract.address && typeof contract.address === 'function') {
|
||||||
contract.addressHandler = contract.address;
|
contract.addressHandler = contract.address;
|
||||||
delete contract.addres;
|
delete contract.address;
|
||||||
} else if (contract.address && typeof contract.address === 'string') {
|
} else if (contract.address && typeof contract.address === 'string') {
|
||||||
contract.deployedAddress = contract.address;
|
contract.deployedAddress = contract.address;
|
||||||
}
|
}
|
||||||
|
@ -385,7 +385,7 @@ export default class ContractsManager {
|
||||||
}
|
}
|
||||||
callback();
|
callback();
|
||||||
},
|
},
|
||||||
/*eslint complexity: ["error", 11]*/
|
// eslint-disable-next-line complexity
|
||||||
function dealWithSpecialConfigs(callback) {
|
function dealWithSpecialConfigs(callback) {
|
||||||
let className, contract, parentContractName, parentContract;
|
let className, contract, parentContractName, parentContract;
|
||||||
let dictionary = Object.keys(self.contracts);
|
let dictionary = Object.keys(self.contracts);
|
||||||
|
@ -393,38 +393,26 @@ export default class ContractsManager {
|
||||||
for (className in self.contracts) {
|
for (className in self.contracts) {
|
||||||
contract = self.contracts[className];
|
contract = self.contracts[className];
|
||||||
|
|
||||||
if (contract.instanceOf === undefined) {
|
if (!contract.instanceOf && !contract.proxyFor) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (contract.instanceOf) {
|
||||||
parentContractName = contract.instanceOf;
|
parentContractName = contract.instanceOf;
|
||||||
parentContract = self.contracts[parentContractName];
|
parentContract = self.contracts[parentContractName];
|
||||||
|
if (!self._isParentContractDependencyCorrect(className, parentContract, 'instanceOf', dictionary)) {
|
||||||
if (parentContract === className) {
|
|
||||||
self.logger.error(__("%s : instanceOf is set to itself", className));
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parentContract === undefined) {
|
// If the contract has no args and the parent has them, use the parent's args in its place
|
||||||
self.logger.error(__("{{className}}: couldn't find instanceOf contract {{parentContractName}}", {
|
if (parentContract.args?.length > 0 && contract.args?.length === 0) {
|
||||||
className: className,
|
|
||||||
parentContractName: parentContractName
|
|
||||||
}));
|
|
||||||
let suggestion = proposeAlternative(parentContractName, dictionary, [className, parentContractName]);
|
|
||||||
if (suggestion) {
|
|
||||||
self.logger.warn(__('did you mean "%s"?', suggestion));
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parentContract.args && parentContract.args.length > 0 && ((contract.args && contract.args.length === 0) || contract.args === undefined)) {
|
|
||||||
contract.args = parentContract.args;
|
contract.args = parentContract.args;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (contract.code !== undefined) {
|
if (!contract.code) {
|
||||||
self.logger.error(__("{{className}} has code associated to it but it's configured as an instanceOf {{parentContractName}}", {
|
self.logger.error(__("{{className}} has code associated to it but it's configured as an instanceOf {{parentContractName}}", {
|
||||||
className: className,
|
className,
|
||||||
parentContractName: parentContractName
|
parentContractName
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -442,7 +430,18 @@ export default class ContractsManager {
|
||||||
contract.gas = contract.gas || parentContract.gas;
|
contract.gas = contract.gas || parentContract.gas;
|
||||||
contract.gasPrice = contract.gasPrice || parentContract.gasPrice;
|
contract.gasPrice = contract.gasPrice || parentContract.gasPrice;
|
||||||
contract.type = 'instance';
|
contract.type = 'instance';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contract.proxyFor) {
|
||||||
|
parentContractName = contract.proxyFor;
|
||||||
|
parentContract = self.contracts[parentContractName];
|
||||||
|
if (!self._isParentContractDependencyCorrect(className, parentContract, 'proxyFor', dictionary)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Merge ABI of contract and proxy so that the contract shares both ABIs, but remove the constructor
|
||||||
|
contract.abiDefinition = contract.abiDefinition.concat(parentContract.abiDefinition.filter(def => def.type !== 'constructor'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
callback();
|
callback();
|
||||||
},
|
},
|
||||||
|
@ -552,6 +551,28 @@ export default class ContractsManager {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_isParentContractDependencyCorrect(className, parentContract, typeOfInheritance, dictionary) {
|
||||||
|
const parentContractName = parentContract.className;
|
||||||
|
if (parentContract === className) {
|
||||||
|
this.logger.error(__("{{className}} : {{typeOfInheritance}} is set to itself", {className, typeOfInheritance}));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parentContract === undefined) {
|
||||||
|
this.logger.error(__("{{className}}: couldn't find {{typeOfInheritance}} contract {{parentContractName}}", {
|
||||||
|
className,
|
||||||
|
parentContractName,
|
||||||
|
typeOfInheritance
|
||||||
|
}));
|
||||||
|
let suggestion = proposeAlternative(parentContractName, dictionary, [className, parentContractName]);
|
||||||
|
if (suggestion) {
|
||||||
|
this.logger.warn(__('did you mean "%s"?', suggestion));
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
_contractsForApi() {
|
_contractsForApi() {
|
||||||
const contracts = this.formatContracts();
|
const contracts = this.formatContracts();
|
||||||
contracts.forEach((contract) => {
|
contracts.forEach((contract) => {
|
||||||
|
|
Loading…
Reference in New Issue