minor changes to contracts

This commit is contained in:
perissology 2018-03-27 10:55:37 -07:00
parent e4c34225ae
commit fb78a616b5
16 changed files with 111 additions and 85 deletions

View File

@ -38,21 +38,22 @@ contract EscapableApp is AragonApp {
mapping (address=>bool) private escapeBlacklist; // Token contract addresses mapping (address=>bool) private escapeBlacklist; // Token contract addresses
uint[20] private storageOffset; // reserve 20 slots for future upgrades uint[20] private storageOffset; // reserve 20 slots for future upgrades
function EscapableApp(address _escapeHatchDestination) public {
_init(_escapeHatchDestination);
}
/// @param _escapeHatchDestination The address of a safe location (usu a /// @param _escapeHatchDestination The address of a safe location (usu a
/// Multisig) to send the ether held in this contract; if a neutral address /// Multisig) to send the ether held in this contract; if a neutral address
/// is required, the WHG Multisig is an option: /// is required, the WHG Multisig is an option:
/// 0x8Ff920020c8AD673661c8117f2855C384758C572 /// 0x8Ff920020c8AD673661c8117f2855C384758C572
function initialize(address _escapeHatchDestination) onlyInit public { function initialize(address _escapeHatchDestination) onlyInit public {
initialized(); _init(_escapeHatchDestination);
require(_escapeHatchDestination != 0x0);
escapeHatchDestination = _escapeHatchDestination;
} }
/// @notice The `escapeHatch()` should only be called as a last resort if a /// @notice The `escapeHatch()` should only be called as a last resort if a
/// security issue is uncovered or something unexpected happened /// security issue is uncovered or something unexpected happened
/// @param _token to transfer, use 0x0 for ether /// @param _token to transfer, use 0x0 for ether
function escapeHatch(address _token) public authP(ESCAPE_HATCH_CALLER_ROLE, arr(_token)) { function escapeHatch(address _token) external authP(ESCAPE_HATCH_CALLER_ROLE, arr(_token)) {
require(escapeBlacklist[_token]==false); require(escapeBlacklist[_token]==false);
uint256 balance; uint256 balance;
@ -75,10 +76,17 @@ contract EscapableApp is AragonApp {
/// @param _token the token address being queried /// @param _token the token address being queried
/// @return False if `_token` is in the blacklist and can't be taken out of /// @return False if `_token` is in the blacklist and can't be taken out of
/// the contract via the `escapeHatch()` /// the contract via the `escapeHatch()`
function isTokenEscapable(address _token) constant public returns (bool) { function isTokenEscapable(address _token) view external returns (bool) {
return !escapeBlacklist[_token]; return !escapeBlacklist[_token];
} }
function _init(address _escapeHatchDestination) internal {
initialized();
require(_escapeHatchDestination != 0x0);
escapeHatchDestination = _escapeHatchDestination;
}
/// @notice Creates the blacklist of tokens that are not able to be taken /// @notice Creates the blacklist of tokens that are not able to be taken
/// out of the contract; can only be done at the deployment, and the logic /// out of the contract; can only be done at the deployment, and the logic
/// to add to the blacklist will be in the constructor of a child contract /// to add to the blacklist will be in the constructor of a child contract

View File

@ -19,7 +19,7 @@ contract LPFactory is LPConstants, DAOFactory {
lpBase = _lpBase; lpBase = _lpBase;
} }
function newLP(address _root, address _escapeHatchDestination) public { function newLP(address _root, address _escapeHatchDestination) external {
Kernel kernel = newDAO(this); Kernel kernel = newDAO(this);
ACL acl = ACL(kernel.acl()); ACL acl = ACL(kernel.acl());
@ -42,13 +42,11 @@ contract LPFactory is LPConstants, DAOFactory {
bytes32 appManagerRole = kernel.APP_MANAGER_ROLE(); bytes32 appManagerRole = kernel.APP_MANAGER_ROLE();
bytes32 permRole = acl.CREATE_PERMISSIONS_ROLE(); bytes32 permRole = acl.CREATE_PERMISSIONS_ROLE();
bytes32 hatchCallerRole = v.ESCAPE_HATCH_CALLER_ROLE(); bytes32 hatchCallerRole = v.ESCAPE_HATCH_CALLER_ROLE();
bytes32 authPaymentRole = v.AUTHORIZE_PAYMENT_ROLE();
bytes32 pluginManagerRole = lp.PLUGIN_MANAGER_ROLE(); bytes32 pluginManagerRole = lp.PLUGIN_MANAGER_ROLE();
acl.createPermission(_root, address(v), hatchCallerRole, _root); acl.createPermission(_root, address(v), hatchCallerRole, _root);
acl.createPermission(_root, address(lp), hatchCallerRole, _root); acl.createPermission(_root, address(lp), hatchCallerRole, _root);
acl.createPermission(_root, address(lp), pluginManagerRole, _root); acl.createPermission(_root, address(lp), pluginManagerRole, _root);
acl.createPermission(address(lp), address(v), authPaymentRole, _root);
// TODO: set pledgeAdminRole manager to 0x0? maybe it doesn't matter b/c it can be recreated by _root anyways // TODO: set pledgeAdminRole manager to 0x0? maybe it doesn't matter b/c it can be recreated by _root anyways
acl.grantPermission(_root, address(kernel), appManagerRole); acl.grantPermission(_root, address(kernel), appManagerRole);

View File

@ -41,7 +41,6 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
bytes32 constant public CONFIRM_PAYMENT_ROLE = keccak256("CONFIRM_PAYMENT_ROLE"); bytes32 constant public CONFIRM_PAYMENT_ROLE = keccak256("CONFIRM_PAYMENT_ROLE");
bytes32 constant public CANCEL_PAYMENT_ROLE = keccak256("CANCEL_PAYMENT_ROLE"); bytes32 constant public CANCEL_PAYMENT_ROLE = keccak256("CANCEL_PAYMENT_ROLE");
bytes32 constant public AUTHORIZE_PAYMENT_ROLE = keccak256("AUTHORIZE_PAYMENT_ROLE");
bytes32 constant public SET_AUTOPAY_ROLE = keccak256("SET_AUTOPAY_ROLE"); bytes32 constant public SET_AUTOPAY_ROLE = keccak256("SET_AUTOPAY_ROLE");
event AutoPaySet(bool autoPay); event AutoPaySet(bool autoPay);
@ -86,6 +85,9 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
_; _;
} }
function LPVault(address _escapeHatchDestination) EscapableApp(_escapeHatchDestination) public {
}
function initialize(address _escapeHatchDestination) onlyInit public { function initialize(address _escapeHatchDestination) onlyInit public {
require(false); // overload the EscapableApp require(false); // overload the EscapableApp
_escapeHatchDestination; _escapeHatchDestination;
@ -125,7 +127,7 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
address _dest, address _dest,
address _token, address _token,
uint _amount uint _amount
) external authP(AUTHORIZE_PAYMENT_ROLE, arr(_dest, _amount)) returns (uint) ) external onlyLiquidPledging returns (uint)
{ {
uint idPayment = payments.length; uint idPayment = payments.length;
payments.length ++; payments.length ++;
@ -150,13 +152,15 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
/// has been authorized /// has been authorized
/// @param _idPayment Array lookup for the payment. /// @param _idPayment Array lookup for the payment.
function confirmPayment(uint _idPayment) public { function confirmPayment(uint _idPayment) public {
Payment storage p = payments[_idPayment];
require(canPerform(msg.sender, CONFIRM_PAYMENT_ROLE, arr(_idPayment, p.amount)));
_doConfirmPayment(_idPayment); _doConfirmPayment(_idPayment);
} }
/// @notice When `autopay` is `false` and after a payment has been authorized /// @notice When `autopay` is `false` and after a payment has been authorized
/// to allow the owner to cancel a payment instead of confirming it. /// to allow the owner to cancel a payment instead of confirming it.
/// @param _idPayment Array lookup for the payment. /// @param _idPayment Array lookup for the payment.
function cancelPayment(uint _idPayment) public { function cancelPayment(uint _idPayment) external {
_doCancelPayment(_idPayment); _doCancelPayment(_idPayment);
} }
@ -164,7 +168,7 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
/// @param _idPayments An array of multiple payment ids /// @param _idPayments An array of multiple payment ids
function multiConfirm(uint[] _idPayments) external { function multiConfirm(uint[] _idPayments) external {
for (uint i = 0; i < _idPayments.length; i++) { for (uint i = 0; i < _idPayments.length; i++) {
_doConfirmPayment(_idPayments[i]); confirmPayment(_idPayments[i]);
} }
} }
@ -181,17 +185,15 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
/// before being thoroughly battle-tested. /// before being thoroughly battle-tested.
/// @param _token to transfer /// @param _token to transfer
/// @param _amount to transfer /// @param _amount to transfer
function escapeFunds(address _token, uint _amount) public authP(ESCAPE_HATCH_CALLER_ROLE, arr(_token)) { function escapeFunds(address _token, uint _amount) external authP(ESCAPE_HATCH_CALLER_ROLE, arr(_token)) {
require(_token != 0x0); require(_token != 0x0);
ERC20 token = ERC20(_token); ERC20 token = ERC20(_token);
uint balance = token.balanceOf(this);
require(balance >= _amount);
require(token.transfer(escapeHatchDestination, _amount)); require(token.transfer(escapeHatchDestination, _amount));
EscapeFundsCalled(_token, _amount); EscapeFundsCalled(_token, _amount);
} }
/// @return The total number of payments that have ever been authorized /// @return The total number of payments that have ever been authorized
function nPayments() public view returns (uint) { function nPayments() external view returns (uint) {
return payments.length; return payments.length;
} }
@ -202,7 +204,6 @@ contract LPVault is EscapableApp, LiquidPledgingACLHelpers {
require(_idPayment < payments.length); require(_idPayment < payments.length);
Payment storage p = payments[_idPayment]; Payment storage p = payments[_idPayment];
require(p.state == PaymentStatus.Pending); require(p.state == PaymentStatus.Pending);
require(canPerform(msg.sender, CONFIRM_PAYMENT_ROLE, arr(_idPayment, p.amount)));
p.state = PaymentStatus.Paid; p.state = PaymentStatus.Paid;
liquidPledging.confirmPayment(uint64(p.ref), p.amount); liquidPledging.confirmPayment(uint64(p.ref), p.amount);

View File

@ -27,6 +27,8 @@ import "./LiquidPledgingBase.sol";
/// to allow for expanded functionality. /// to allow for expanded functionality.
contract LiquidPledging is LiquidPledgingBase { contract LiquidPledging is LiquidPledgingBase {
function LiquidPledging(address _escapeHatchDestination) EscapableApp(_escapeHatchDestination) public {
}
function addGiverAndDonate(uint64 idReceiver, address token, uint amount) function addGiverAndDonate(uint64 idReceiver, address token, uint amount)
public public
@ -48,7 +50,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// found), the amount of ETH donated in wei is added to the `amount` in /// found), the amount of ETH donated in wei is added to the `amount` in
/// the Giver's Pledge, and an LP transfer is done to the idReceiver for /// the Giver's Pledge, and an LP transfer is done to the idReceiver for
/// the full amount /// the full amount
/// @param idGiver The id of the Giver donating; if 0, a new id is created /// @param idGiver The id of the Giver donating
/// @param idReceiver The Admin receiving the donation; can be any Admin: /// @param idReceiver The Admin receiving the donation; can be any Admin:
/// the Giver themselves, another Giver, a Delegate or a Project /// the Giver themselves, another Giver, a Delegate or a Project
function donate(uint64 idGiver, uint64 idReceiver, address token, uint amount) function donate(uint64 idGiver, uint64 idReceiver, address token, uint amount)
@ -61,6 +63,9 @@ contract LiquidPledging is LiquidPledgingBase {
PledgeAdmin storage sender = _findAdmin(idGiver); PledgeAdmin storage sender = _findAdmin(idGiver);
require(sender.adminType == PledgeAdminType.Giver); require(sender.adminType == PledgeAdminType.Giver);
// TODO should this be done at the end of this function?
// what re-entrancy issues are there if this is done here?
// if done at the end of the function, will that affect plugins?
require(ERC20(token).transferFrom(msg.sender, address(vault), amount)); // transfer the token to the `vault` require(ERC20(token).transferFrom(msg.sender, address(vault), amount)); // transfer the token to the `vault`
uint64 idPledge = _findOrCreatePledge( uint64 idPledge = _findOrCreatePledge(
@ -97,7 +102,7 @@ contract LiquidPledging is LiquidPledgingBase {
uint64 idReceiver uint64 idReceiver
) public ) public
{ {
checkAdminOwner(idSender); _checkAdminOwner(idSender);
_transfer(idSender, idPledge, amount, idReceiver); _transfer(idSender, idPledge, amount, idReceiver);
} }
@ -111,7 +116,7 @@ contract LiquidPledging is LiquidPledgingBase {
Pledge storage p = _findPledge(idPledge); Pledge storage p = _findPledge(idPledge);
require(p.pledgeState == PledgeState.Pledged); require(p.pledgeState == PledgeState.Pledged);
checkAdminOwner(p.owner); _checkAdminOwner(p.owner);
uint64 idNewPledge = _findOrCreatePledge( uint64 idNewPledge = _findOrCreatePledge(
p.owner, p.owner,
@ -180,7 +185,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// @param idProject Id of the project that is to be canceled /// @param idProject Id of the project that is to be canceled
function cancelProject(uint64 idProject) public { function cancelProject(uint64 idProject) public {
PledgeAdmin storage project = _findAdmin(idProject); PledgeAdmin storage project = _findAdmin(idProject);
checkAdminOwner(idProject); _checkAdminOwner(idProject);
project.canceled = true; project.canceled = true;
CancelProject(idProject); CancelProject(idProject);
@ -196,7 +201,8 @@ contract LiquidPledging is LiquidPledgingBase {
Pledge storage p = _findPledge(idPledge); Pledge storage p = _findPledge(idPledge);
require(p.oldPledge != 0); require(p.oldPledge != 0);
checkAdminOwner(p.owner); require(p.pledgeState == PledgeState.Pledged);
_checkAdminOwner(p.owner);
uint64 oldPledge = _getOldestPledgeNotCanceled(p.oldPledge); uint64 oldPledge = _getOldestPledgeNotCanceled(p.oldPledge);
_doTransfer(idPledge, oldPledge, amount); _doTransfer(idPledge, oldPledge, amount);
@ -231,7 +237,7 @@ contract LiquidPledging is LiquidPledgingBase {
) public ) public
{ {
for (uint i = 0; i < pledgesAmounts.length; i++ ) { for (uint i = 0; i < pledgesAmounts.length; i++ ) {
uint64 idPledge = uint64( pledgesAmounts[i] & (D64-1) ); uint64 idPledge = uint64(pledgesAmounts[i] & (D64-1));
uint amount = pledgesAmounts[i] / D64; uint amount = pledgesAmounts[i] / D64;
transfer(idSender, idPledge, amount, idReceiver); transfer(idSender, idPledge, amount, idReceiver);
@ -245,7 +251,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// bitmask /// bitmask
function mWithdraw(uint[] pledgesAmounts) public { function mWithdraw(uint[] pledgesAmounts) public {
for (uint i = 0; i < pledgesAmounts.length; i++ ) { for (uint i = 0; i < pledgesAmounts.length; i++ ) {
uint64 idPledge = uint64( pledgesAmounts[i] & (D64-1) ); uint64 idPledge = uint64(pledgesAmounts[i] & (D64-1));
uint amount = pledgesAmounts[i] / D64; uint amount = pledgesAmounts[i] / D64;
withdraw(idPledge, amount); withdraw(idPledge, amount);
@ -258,7 +264,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// using the D64 bitmask /// using the D64 bitmask
function mConfirmPayment(uint[] pledgesAmounts) public { function mConfirmPayment(uint[] pledgesAmounts) public {
for (uint i = 0; i < pledgesAmounts.length; i++ ) { for (uint i = 0; i < pledgesAmounts.length; i++ ) {
uint64 idPledge = uint64( pledgesAmounts[i] & (D64-1) ); uint64 idPledge = uint64(pledgesAmounts[i] & (D64-1));
uint amount = pledgesAmounts[i] / D64; uint amount = pledgesAmounts[i] / D64;
confirmPayment(idPledge, amount); confirmPayment(idPledge, amount);
@ -271,7 +277,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// using the D64 bitmask /// using the D64 bitmask
function mCancelPayment(uint[] pledgesAmounts) public { function mCancelPayment(uint[] pledgesAmounts) public {
for (uint i = 0; i < pledgesAmounts.length; i++ ) { for (uint i = 0; i < pledgesAmounts.length; i++ ) {
uint64 idPledge = uint64( pledgesAmounts[i] & (D64-1) ); uint64 idPledge = uint64(pledgesAmounts[i] & (D64-1));
uint amount = pledgesAmounts[i] / D64; uint amount = pledgesAmounts[i] / D64;
cancelPayment(idPledge, amount); cancelPayment(idPledge, amount);
@ -283,7 +289,7 @@ contract LiquidPledging is LiquidPledgingBase {
/// @param pledges An array of pledge IDs /// @param pledges An array of pledge IDs
function mNormalizePledge(uint64[] pledges) public { function mNormalizePledge(uint64[] pledges) public {
for (uint i = 0; i < pledges.length; i++ ) { for (uint i = 0; i < pledges.length; i++ ) {
normalizePledge( pledges[i] ); normalizePledge(pledges[i]);
} }
} }
} }

View File

@ -29,7 +29,6 @@ import "./EscapableApp.sol";
/// data structures /// data structures
contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins, Pledges { contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins, Pledges {
// Event Declarations
event Transfer(uint indexed from, uint indexed to, uint amount); event Transfer(uint indexed from, uint indexed to, uint amount);
event CancelProject(uint indexed idProject); event CancelProject(uint indexed idProject);
@ -76,7 +75,7 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
/// @notice Getter to find Delegate w/ the Pledge ID & the Delegate index /// @notice Getter to find Delegate w/ the Pledge ID & the Delegate index
/// @param idPledge The id number representing the pledge being queried /// @param idPledge The id number representing the pledge being queried
/// @param idxDelegate The index number for the delegate in this Pledge /// @param idxDelegate The index number for the delegate in this Pledge
function getPledgeDelegate(uint64 idPledge, uint64 idxDelegate) public view returns( function getPledgeDelegate(uint64 idPledge, uint64 idxDelegate) external view returns(
uint64 idDelegate, uint64 idDelegate,
address addr, address addr,
string name string name
@ -88,6 +87,10 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
name = delegate.name; name = delegate.name;
} }
///////////////////
// Public functions
///////////////////
/// @notice Only affects pledges with the Pledged PledgeState for 2 things: /// @notice Only affects pledges with the Pledged PledgeState for 2 things:
/// #1: Checks if the pledge should be committed. This means that /// #1: Checks if the pledge should be committed. This means that
/// if the pledge has an intendedProject and it is past the /// if the pledge has an intendedProject and it is past the
@ -154,7 +157,7 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
/// @notice A check to see if the msg.sender is the owner or the /// @notice A check to see if the msg.sender is the owner or the
/// plugin contract for a specific Admin /// plugin contract for a specific Admin
/// @param idAdmin The id of the admin being checked /// @param idAdmin The id of the admin being checked
function checkAdminOwner(uint64 idAdmin) internal constant { function _checkAdminOwner(uint64 idAdmin) internal view {
PledgeAdmin storage a = _findAdmin(idAdmin); PledgeAdmin storage a = _findAdmin(idAdmin);
require(msg.sender == address(a.plugin) || msg.sender == a.addr); require(msg.sender == address(a.plugin) || msg.sender == a.addr);
} }
@ -179,8 +182,10 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
if (receiver.adminType == PledgeAdminType.Giver) { if (receiver.adminType == PledgeAdminType.Giver) {
_transferOwnershipToGiver(idPledge, amount, idReceiver); _transferOwnershipToGiver(idPledge, amount, idReceiver);
return;
} else if (receiver.adminType == PledgeAdminType.Project) { } else if (receiver.adminType == PledgeAdminType.Project) {
_transferOwnershipToProject(idPledge, amount, idReceiver); _transferOwnershipToProject(idPledge, amount, idReceiver);
return;
} else if (receiver.adminType == PledgeAdminType.Delegate) { } else if (receiver.adminType == PledgeAdminType.Delegate) {
uint recieverDIdx = _getDelegateIdx(p, idReceiver); uint recieverDIdx = _getDelegateIdx(p, idReceiver);
@ -199,26 +204,26 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
p.token, p.token,
PledgeState.Pledged); PledgeState.Pledged);
_doTransfer(idPledge, toPledge, amount); _doTransfer(idPledge, toPledge, amount);
} else { return;
_undelegate(idPledge, amount, p.delegationChain.length - receiverDIdx - 1);
} }
} else {
// owner is not vetoing an intendedProject and is transferring the pledge to a delegate,
// so we want to reset the delegationChain
idPledge = _undelegate(
idPledge,
amount,
p.delegationChain.length
);
_appendDelegate(idPledge, amount, idReceiver);
}
} else { _undelegate(idPledge, amount, p.delegationChain.length - receiverDIdx - 1);
// This should never be reached as the receiver.adminType return;
// should always be either a Giver, Project, or Delegate }
assert(false); // owner is not vetoing an intendedProject and is transferring the pledge to a delegate,
// so we want to reset the delegationChain
idPledge = _undelegate(
idPledge,
amount,
p.delegationChain.length
);
_appendDelegate(idPledge, amount, idReceiver);
return;
} }
return;
// This should never be reached as the receiver.adminType
// should always be either a Giver, Project, or Delegate
assert(false);
} }
// If the sender is a Delegate // If the sender is a Delegate
@ -245,6 +250,7 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
p.delegationChain.length - senderDIdx - 1 p.delegationChain.length - senderDIdx - 1
); );
_appendDelegate(idPledge, amount, idReceiver); _appendDelegate(idPledge, amount, idReceiver);
return;
// And part of the delegationChain and is after the sender, then // And part of the delegationChain and is after the sender, then
// all of the other delegates after the sender are removed and // all of the other delegates after the sender are removed and
@ -256,17 +262,18 @@ contract LiquidPledgingBase is EscapableApp, LiquidPledgingStorage, PledgeAdmins
p.delegationChain.length - senderDIdx - 1 p.delegationChain.length - senderDIdx - 1
); );
_appendDelegate(idPledge, amount, idReceiver); _appendDelegate(idPledge, amount, idReceiver);
return;
}
// And is already part of the delegate chain but is before the // And is already part of the delegate chain but is before the
// sender, then the sender and all of the other delegates after // sender, then the sender and all of the other delegates after
// the RECEIVER are removed from the delegationChain // the RECEIVER are removed from the delegationChain
} else if (receiverDIdx <= senderDIdx) {//TODO Check for Game Theory issues (from Arthur) this allows the sender to sort of go komakosi and remove himself and the delegates between himself and the receiver... should this authority be allowed? //TODO Check for Game Theory issues (from Arthur) this allows the sender to sort of go komakosi and remove himself and the delegates between himself and the receiver... should this authority be allowed?
_undelegate( _undelegate(
idPledge, idPledge,
amount, amount,
p.delegationChain.length - receiverDIdx - 1 p.delegationChain.length - receiverDIdx - 1
); );
}
return; return;
} }

View File

@ -28,6 +28,9 @@ contract LiquidPledgingMock is LiquidPledging {
uint public mock_time; uint public mock_time;
function LiquidPledgingMock(address _escapeHatchDestination) LiquidPledging(_escapeHatchDestination) public {
}
/// @dev `LiquidPledgingMock` creates a standard `LiquidPledging` /// @dev `LiquidPledgingMock` creates a standard `LiquidPledging`
/// instance and sets the mocked time to the current blocktime. /// instance and sets the mocked time to the current blocktime.
function initialize(address _vault, address _escapeHatchDestination) onlyInit public { function initialize(address _vault, address _escapeHatchDestination) onlyInit public {

View File

@ -27,7 +27,7 @@ contract LiquidPledgingPlugins is AragonApp, LiquidPledgingStorage, LiquidPledgi
bytes32 constant public PLUGIN_MANAGER_ROLE = keccak256("PLUGIN_MANAGER_ROLE"); bytes32 constant public PLUGIN_MANAGER_ROLE = keccak256("PLUGIN_MANAGER_ROLE");
function addValidPluginInstance(address addr) auth(PLUGIN_MANAGER_ROLE) public { function addValidPluginInstance(address addr) auth(PLUGIN_MANAGER_ROLE) external {
pluginInstanceWhitelist[addr] = true; pluginInstanceWhitelist[addr] = true;
} }
@ -45,7 +45,7 @@ contract LiquidPledgingPlugins is AragonApp, LiquidPledgingStorage, LiquidPledgi
pluginContractWhitelist[contractHash] = false; pluginContractWhitelist[contractHash] = false;
} }
function removeValidPluginInstance(address addr) external auth(PLUGIN_MANAGER_ROLE) { function removeValidPluginInstance(address addr) external authP(PLUGIN_MANAGER_ROLE, arr(addr)) {
pluginInstanceWhitelist[addr] = false; pluginInstanceWhitelist[addr] = false;
} }

View File

@ -52,7 +52,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
string url, string url,
uint64 commitTime, uint64 commitTime,
ILiquidPledgingPlugin plugin ILiquidPledgingPlugin plugin
) public returns (uint64 idGiver) ) external returns (uint64 idGiver)
{ {
return addGiver( return addGiver(
msg.sender, msg.sender,
@ -107,7 +107,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
string newName, string newName,
string newUrl, string newUrl,
uint64 newCommitTime uint64 newCommitTime
) public ) external
{ {
PledgeAdmin storage giver = _findAdmin(idGiver); PledgeAdmin storage giver = _findAdmin(idGiver);
require(msg.sender == giver.addr); require(msg.sender == giver.addr);
@ -135,7 +135,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
string url, string url,
uint64 commitTime, uint64 commitTime,
ILiquidPledgingPlugin plugin ILiquidPledgingPlugin plugin
) public returns (uint64 idDelegate) ) external returns (uint64 idDelegate)
{ {
require(isValidPlugin(plugin)); // Plugin check require(isValidPlugin(plugin)); // Plugin check
@ -173,7 +173,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
string newName, string newName,
string newUrl, string newUrl,
uint64 newCommitTime uint64 newCommitTime
) public ) external
{ {
PledgeAdmin storage delegate = _findAdmin(idDelegate); PledgeAdmin storage delegate = _findAdmin(idDelegate);
require(msg.sender == delegate.addr); require(msg.sender == delegate.addr);
@ -205,7 +205,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
uint64 parentProject, uint64 parentProject,
uint64 commitTime, uint64 commitTime,
ILiquidPledgingPlugin plugin ILiquidPledgingPlugin plugin
) public returns (uint64 idProject) ) external returns (uint64 idProject)
{ {
require(isValidPlugin(plugin)); require(isValidPlugin(plugin));
@ -248,7 +248,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
string newName, string newName,
string newUrl, string newUrl,
uint64 newCommitTime uint64 newCommitTime
) public ) external
{ {
PledgeAdmin storage project = _findAdmin(idProject); PledgeAdmin storage project = _findAdmin(idProject);
@ -269,7 +269,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
/// @notice A constant getter used to check how many total Admins exist /// @notice A constant getter used to check how many total Admins exist
/// @return The total number of admins (Givers, Delegates and Projects) . /// @return The total number of admins (Givers, Delegates and Projects) .
function numberOfPledgeAdmins() public constant returns(uint) { function numberOfPledgeAdmins() external view returns(uint) {
return admins.length - 1; return admins.length - 1;
} }
@ -286,7 +286,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
/// canceled /// canceled
/// @return plugin This is Project's liquidPledging plugin allowing for /// @return plugin This is Project's liquidPledging plugin allowing for
/// extended functionality /// extended functionality
function getPledgeAdmin(uint64 idAdmin) public view returns ( function getPledgeAdmin(uint64 idAdmin) external view returns (
PledgeAdminType adminType, PledgeAdminType adminType,
address addr, address addr,
string name, string name,
@ -311,7 +311,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
/// @param projectId The Admin id number used to specify the Project /// @param projectId The Admin id number used to specify the Project
/// @return True if the Project has been canceled /// @return True if the Project has been canceled
function isProjectCanceled(uint64 projectId) function isProjectCanceled(uint64 projectId)
public constant returns (bool) public view returns (bool)
{ {
PledgeAdmin storage a = _findAdmin(projectId); PledgeAdmin storage a = _findAdmin(projectId);
@ -347,7 +347,7 @@ contract PledgeAdmins is AragonApp, LiquidPledgingPlugins {
/// using a recursive loop /// using a recursive loop
/// @param a The project admin being queried /// @param a The project admin being queried
/// @return The level of authority a specific Project has /// @return The level of authority a specific Project has
function _getProjectLevel(PledgeAdmin a) internal returns(uint64) { function _getProjectLevel(PledgeAdmin a) internal view returns(uint64) {
assert(a.adminType == PledgeAdminType.Project); assert(a.adminType == PledgeAdminType.Project);
if (a.parentProject == 0) { if (a.parentProject == 0) {

View File

@ -36,7 +36,7 @@ contract Pledges is AragonApp, LiquidPledgingStorage {
/// @notice A constant getter that returns the total number of pledges /// @notice A constant getter that returns the total number of pledges
/// @return The total number of Pledges in the system /// @return The total number of Pledges in the system
function numberOfPledges() public view returns (uint) { function numberOfPledges() external view returns (uint) {
return pledges.length - 1; return pledges.length - 1;
} }
@ -45,7 +45,7 @@ contract Pledges is AragonApp, LiquidPledgingStorage {
/// @return the amount, owner, the number of delegates (but not the actual /// @return the amount, owner, the number of delegates (but not the actual
/// delegates, the intendedProject (if any), the current commit time and /// delegates, the intendedProject (if any), the current commit time and
/// the previous pledge this pledge was derived from /// the previous pledge this pledge was derived from
function getPledge(uint64 idPledge) public view returns( function getPledge(uint64 idPledge) external view returns(
uint amount, uint amount,
uint64 owner, uint64 owner,
uint64 nDelegates, uint64 nDelegates,

View File

@ -12,7 +12,7 @@ contract TestSimpleDelegatePlugin {
event BeforeTransfer(uint64 pledgeAdmin, uint64 pledgeFrom, uint64 pledgeTo, uint64 context, uint amount); event BeforeTransfer(uint64 pledgeAdmin, uint64 pledgeFrom, uint64 pledgeTo, uint64 context, uint amount);
event AfterTransfer(uint64 pledgeAdmin, uint64 pledgeFrom, uint64 pledgeTo, uint64 context, uint amount); event AfterTransfer(uint64 pledgeAdmin, uint64 pledgeFrom, uint64 pledgeTo, uint64 context, uint amount);
function TestSimpleDelegatePlugin(LiquidPledging _liquidPledging) { function TestSimpleDelegatePlugin(LiquidPledging _liquidPledging) public {
require(msg.sender != tx.origin); // Avoids being created directly by mistake. require(msg.sender != tx.origin); // Avoids being created directly by mistake.
liquidPledging = _liquidPledging; liquidPledging = _liquidPledging;
initPending = true; initPending = true;
@ -22,7 +22,7 @@ contract TestSimpleDelegatePlugin {
string name, string name,
string url, string url,
uint64 commitTime uint64 commitTime
) { ) public {
require(initPending); require(initPending);
idDelegate = liquidPledging.addDelegate(name, url, commitTime, ILiquidPledgingPlugin(this)); idDelegate = liquidPledging.addDelegate(name, url, commitTime, ILiquidPledgingPlugin(this));
initPending = false; initPending = false;
@ -54,12 +54,12 @@ contract TestSimpleDelegatePlugin {
contract TestSimpleDelegatePluginFactory { contract TestSimpleDelegatePluginFactory {
function TestSimpleDelegatePluginFactory ( function TestSimpleDelegatePluginFactory(
LiquidPledging liquidPledging, LiquidPledging liquidPledging,
string name, string name,
string url, string url,
uint64 commitTime uint64 commitTime
) { ) public {
TestSimpleDelegatePlugin d = new TestSimpleDelegatePlugin(liquidPledging); TestSimpleDelegatePlugin d = new TestSimpleDelegatePlugin(liquidPledging);
d.init(name, url, commitTime); d.init(name, url, commitTime);
} }

View File

@ -52,8 +52,8 @@ describe('LiquidPledging plugins test', function () {
}); });
it('Should deploy LiquidPledging contract', async function () { it('Should deploy LiquidPledging contract', async function () {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, accounts[0]);
const baseLP = await contracts.LiquidPledgingMock.new(web3); const baseLP = await contracts.LiquidPledgingMock.new(web3, accounts[0]);
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
const r = await lpFactory.newLP(accounts[0], accounts[0]); const r = await lpFactory.newLP(accounts[0], accounts[0]);

View File

@ -49,8 +49,8 @@ describe('LiquidPledging cancelPledge normal scenario', function () {
}); });
it('Should deploy LiquidPledging contract', async () => { it('Should deploy LiquidPledging contract', async () => {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, accounts[0]);
const baseLP = await contracts.LiquidPledgingMock.new(web3); const baseLP = await contracts.LiquidPledgingMock.new(web3, accounts[0]);
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
const r = await lpFactory.newLP(accounts[0], accounts[0]); const r = await lpFactory.newLP(accounts[0], accounts[0]);

View File

@ -56,8 +56,8 @@ describe('DelegationChain test', function () {
}); });
it('Should deploy LiquidPledging contract', async () => { it('Should deploy LiquidPledging contract', async () => {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, accounts[0]);
const baseLP = await contracts.LiquidPledgingMock.new(web3); const baseLP = await contracts.LiquidPledgingMock.new(web3, accounts[0]);
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
const r = await lpFactory.newLP(accounts[0], accounts[0]); const r = await lpFactory.newLP(accounts[0], accounts[0]);

View File

@ -67,10 +67,13 @@ describe('LiquidPledging test', function () {
}); });
it('Should deploy LiquidPledging contract', async () => { it('Should deploy LiquidPledging contract', async () => {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, escapeHatchDestination);
const baseLP = await contracts.LiquidPledgingMock.new(web3, {gas: 6700000}); const baseLP = await contracts.LiquidPledgingMock.new(web3, escapeHatchDestination, {gas: 6700000});
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
assert.isAbove(Number(await baseVault.getInitializationBlock()), 0);
assert.isAbove(Number(await baseLP.getInitializationBlock()), 0);
const r = await lpFactory.newLP(accounts[0], escapeHatchDestination); const r = await lpFactory.newLP(accounts[0], escapeHatchDestination);
const vaultAddress = r.events.DeployVault.returnValues.vault; const vaultAddress = r.events.DeployVault.returnValues.vault;

View File

@ -54,8 +54,8 @@ describe('NormalizePledge test', function () {
}); });
it('Should deploy LiquidPledging contract', async () => { it('Should deploy LiquidPledging contract', async () => {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, accounts[0]);
const baseLP = await contracts.LiquidPledgingMock.new(web3); const baseLP = await contracts.LiquidPledgingMock.new(web3, accounts[0]);
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
const r = await lpFactory.newLP(accounts[0], accounts[0]); const r = await lpFactory.newLP(accounts[0], accounts[0]);

View File

@ -50,8 +50,8 @@ describe('Vault test', function () {
}); });
it('Should deploy Vault contract', async function () { it('Should deploy Vault contract', async function () {
const baseVault = await contracts.LPVault.new(web3); const baseVault = await contracts.LPVault.new(web3, escapeHatchDestination);
const baseLP = await contracts.LiquidPledgingMock.new(web3); const baseLP = await contracts.LiquidPledgingMock.new(web3, escapeHatchDestination);
lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address); lpFactory = await contracts.LPFactory.new(web3, baseVault.$address, baseLP.$address);
const r = await lpFactory.newLP(accounts[0], escapeHatchDestination); const r = await lpFactory.newLP(accounts[0], escapeHatchDestination);