mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-10 13:55:45 +00:00
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:
parent
03ca790ffd
commit
2f5c16b8cd
@ -66,26 +66,26 @@ class ENS {
|
|||||||
async.map(
|
async.map(
|
||||||
this.config.namesystemConfig.dappConnection || this.config.contractsConfig.dappConnection,
|
this.config.namesystemConfig.dappConnection || this.config.contractsConfig.dappConnection,
|
||||||
(conn, next) => {
|
(conn, next) => {
|
||||||
if (conn === '$EMBARK') {
|
if (conn === '$EMBARK') {
|
||||||
return this.events.request('proxy:endpoint:get', next);
|
return this.events.request('proxy:endpoint:get', next);
|
||||||
}
|
}
|
||||||
next(null, conn);
|
next(null, conn);
|
||||||
}, (err, connections) => {
|
}, (err, connections) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
return done(err);
|
return done(err);
|
||||||
}
|
}
|
||||||
done(null, {
|
done(null, {
|
||||||
env: this.env,
|
env: this.env,
|
||||||
registration: this.config.namesystemConfig.register,
|
registration: this.config.namesystemConfig.register,
|
||||||
registryAbi: this.ensConfig.ENSRegistry.abiDefinition,
|
registryAbi: this.ensConfig.ENSRegistry.abiDefinition,
|
||||||
registryAddress: this.ensConfig.ENSRegistry.deployedAddress,
|
registryAddress: this.ensConfig.ENSRegistry.deployedAddress,
|
||||||
registrarAbi: this.ensConfig.FIFSRegistrar.abiDefinition,
|
registrarAbi: this.ensConfig.FIFSRegistrar.abiDefinition,
|
||||||
registrarAddress: this.ensConfig.FIFSRegistrar.deployedAddress,
|
registrarAddress: this.ensConfig.FIFSRegistrar.deployedAddress,
|
||||||
resolverAbi: this.ensConfig.Resolver.abiDefinition,
|
resolverAbi: this.ensConfig.Resolver.abiDefinition,
|
||||||
resolverAddress: this.ensConfig.Resolver.deployedAddress,
|
resolverAddress: this.ensConfig.Resolver.deployedAddress,
|
||||||
dappConnection: connections
|
dappConnection: connections
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async init(cb = () => {}) {
|
async init(cb = () => {}) {
|
||||||
@ -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);
|
||||||
|
@ -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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user