Skip to content

Commit

Permalink
Merge pull request omni#24 from akolotov/poa-dev-2
Browse files Browse the repository at this point in the history
Initial support of simple deployment procedure for several bridge instances
  • Loading branch information
rstormsf authored Feb 28, 2018
2 parents f528816 + 6d100bf commit 218300c
Showing 1 changed file with 59 additions and 2 deletions.
61 changes: 59 additions & 2 deletions contracts/bridge.sol
Original file line number Diff line number Diff line change
Expand Up @@ -190,8 +190,64 @@ library MessageTest {
}
}

/// This contract introduces a new field which can be used by new bridge
/// instances to get information when the bridge contract was deployed.
/// This will avoid necessity to distribute this information as part of the
/// database file to new validators if they want to join to existing
/// bridge validators group.
/// So, now bridge deployment script or webapp could pickup HomeBridge
/// and ForeignBridge addresses and request block deployed from the contracts
/// in order to generate correct database file.
contract BridgeDeploymentAddressStorage {
uint256 public deployedAtBlock;

function BridgeDeploymentAddressStorage() public {
deployedAtBlock = block.number;
}
}

/// Due to nature of bridge operations it makes sense to have the same value
/// of gas consumption limits which will distributed among all validators serving
/// particular bridge. This approach introduces few advantages:
/// --- new bridge instances will pickup limits from the contract instead of
/// looking at the configuration file (this configuration parameters could be
/// depricated)
/// --- as soon as upgradable bridge contract is implemented these limits needs
/// to be updated every time the contract is upgraded. Validators could get
/// an event that limits updated and use new values to send transactions.
contract HomeBridgeGasConsumptionLimitsStorage {
uint256 public gasLimitWithdrawRelay;

event GasConsumptionLimitsUpdated(uint256);

function setGasLimitWithdrawRelay(uint256 gas) {
gasLimitWithdrawRelay = gas;

GasConsumptionLimitsUpdated(gasLimitWithdrawRelay);
}
}

contract ForeignBridgeGasConsumptionLimitsStorage {
uint256 public gasLimitDepositRelay;
uint256 public gasLimitWithdrawConfirm;

event GasConsumptionLimitsUpdated(uint256, uint256);

function setGasLimitDepositRelay(uint256 gas) {
gasLimitDepositRelay = gas;

GasConsumptionLimitsUpdated(gasLimitDepositRelay, gasLimitWithdrawConfirm);
}

function setGasLimitWithdrawConfirm(uint256 gas) {
gasLimitWithdrawConfirm = gas;

GasConsumptionLimitsUpdated(gasLimitDepositRelay, gasLimitWithdrawConfirm);
}
}

contract HomeBridge {
contract HomeBridge is BridgeDeploymentAddressStorage,
HomeBridgeGasConsumptionLimitsStorage {
/// Number of authorities signatures required to withdraw the money.
///
/// Must be lesser than number of authorities.
Expand Down Expand Up @@ -294,7 +350,8 @@ contract ERC20 {
function allowance(address owner, address spender) public constant returns (uint256);
}

contract ForeignBridge {
contract ForeignBridge is BridgeDeploymentAddressStorage,
ForeignBridgeGasConsumptionLimitsStorage {
/// Number of authorities signatures required to withdraw the money.
///
/// Must be less than number of authorities.
Expand Down

0 comments on commit 218300c

Please sign in to comment.