fix(@embark/contracts): fix ENS contracts not being resolved as deps

This was caused by the fact that we add the ENS contract to the
manager when before they deploy, but the dependency resolution was
done while building the contracts, so even before.
So the solution was to add a "before build" action so that the ENS
module could add its contracts to the manager if needed.
This commit is contained in:
Jonathan Rainville 2020-01-28 15:17:55 -05:00
parent 03ca790ffd
commit 2f5c16b8cd
2 changed files with 36 additions and 21 deletions

View File

@ -110,6 +110,7 @@ class ENS {
return; return;
} }
this.actionsRegistered = true; this.actionsRegistered = true;
this.embark.registerActionForEvent("contracts:build:before", this.beforeContractBuild.bind(this));
this.embark.registerActionForEvent("deployment:deployContracts:beforeAll", this.configureContractsAndRegister.bind(this)); this.embark.registerActionForEvent("deployment:deployContracts:beforeAll", this.configureContractsAndRegister.bind(this));
this.embark.registerActionForEvent('deployment:contract:beforeDeploy', this.modifyENSArguments.bind(this)); this.embark.registerActionForEvent('deployment:contract:beforeDeploy', this.modifyENSArguments.bind(this));
this.embark.registerActionForEvent("deployment:deployContracts:afterAll", this.associateContractAddresses.bind(this)); this.embark.registerActionForEvent("deployment:deployContracts:afterAll", this.associateContractAddresses.bind(this));
@ -271,6 +272,17 @@ class ENS {
}); });
} }
async beforeContractBuild(_options, cb) {
if (this.configured) {
return cb();
}
// Add contracts to contract manager so that they can be resolved as dependencies
this.ensConfig.ENSRegistry = await this.events.request2('contracts:add', this.ensConfig.ENSRegistry);
this.ensConfig.Resolver = await this.events.request2('contracts:add', this.ensConfig.Resolver);
this.ensConfig.FIFSRegistrar = await this.events.request2('contracts:add', this.ensConfig.FIFSRegistrar);
cb();
}
async configureContractsAndRegister(_options, cb) { async configureContractsAndRegister(_options, cb) {
const NO_REGISTRATION = 'NO_REGISTRATION'; const NO_REGISTRATION = 'NO_REGISTRATION';
const self = this; const self = this;
@ -292,8 +304,8 @@ class ENS {
const registration = this.config.namesystemConfig.register; const registration = this.config.namesystemConfig.register;
const doRegister = registration && registration.rootDomain; const doRegister = registration && registration.rootDomain;
this.ensConfig.ENSRegistry = await this.events.request2('contracts:add', this.ensConfig.ENSRegistry);
await this.events.request2('deployment:contract:deploy', this.ensConfig.ENSRegistry); await this.events.request2('deployment:contract:deploy', this.ensConfig.ENSRegistry);
// Add Resolver to contract manager again but this time with correct arguments (Registry address)
this.ensConfig.Resolver.args = [this.ensConfig.ENSRegistry.deployedAddress]; this.ensConfig.Resolver.args = [this.ensConfig.ENSRegistry.deployedAddress];
this.ensConfig.Resolver = await this.events.request2('contracts:add', this.ensConfig.Resolver); this.ensConfig.Resolver = await this.events.request2('contracts:add', this.ensConfig.Resolver);
await this.events.request2('deployment:contract:deploy', this.ensConfig.Resolver); await this.events.request2('deployment:contract:deploy', this.ensConfig.Resolver);

View File

@ -263,7 +263,10 @@ export default class ContractsManager {
const self = this; const self = this;
async.waterfall([ async.waterfall([
function prepareContractsFromConfig(callback) { function beforeBuild(callback) {
self.plugins.emitAndRunActionsForEvent('contracts:build:before', callback);
},
function prepareContractsFromConfig(_options, callback) {
self.events.emit("status", __("Building...")); self.events.emit("status", __("Building..."));
if (contractsConfig.contracts.deploy) { if (contractsConfig.contracts.deploy) {