reorder functions

This commit is contained in:
Ricardo Guilherme Schmidt 2018-05-09 01:34:33 -03:00
parent 80aaa9a561
commit 310b0074f1
1 changed files with 154 additions and 131 deletions

View File

@ -50,14 +50,6 @@ contract Identity is ERC725, ERC735, MessageSigned {
_; _;
} }
modifier managerOrActor(bytes32 _key) {
require(
isKeyPurpose(_key, MANAGEMENT_KEY) ||
isKeyPurpose(_key, ACTION_KEY)
);
_;
}
modifier keyMessageSigned ( modifier keyMessageSigned (
bytes32 _key, bytes32 _key,
bytes32 _messageHash, bytes32 _messageHash,
@ -86,42 +78,84 @@ contract Identity is ERC725, ERC735, MessageSigned {
} }
function managerReset(bytes32 _newKey) ////////////////
// Execute calls and multisig approval
////////////////
function execute(
address _to,
uint256 _value,
bytes _data
)
public public
recoveryOnly returns (uint256 txId)
{ {
recoveryManager = _newKey; txId = _execute(keccak256(msg.sender), _to, _value, _data);
_addKey(keccak256(recoveryManager), MANAGEMENT_KEY, 0);
purposeThreshold[MANAGEMENT_KEY] = keysByPurpose[MANAGEMENT_KEY].length;
} }
function processManagerReset(uint256 _limit) function approve(uint256 _id, bool _approval)
public public
returns (bool success)
{ {
require(recoveryManager != 0); return _approveRequest(keccak256(msg.sender), _id, _approval);
uint256 limit = _limit;
bytes32 newKey = recoveryManager;
bytes32[] memory managers = keysByPurpose[MANAGEMENT_KEY];
uint256 totalManagers = managers.length;
if (limit == 0) {
limit = totalManagers;
} }
purposeThreshold[MANAGEMENT_KEY] = totalManagers - limit + 1; ////////////////
for (uint256 i = 0; i < limit; i++) { // Message Signed functions
bytes32 manager = managers[i]; ////////////////
if (manager != newKey) {
_removeKey(manager, MANAGEMENT_KEY); function executeMessageSigned(
totalManagers--; address _to,
} uint256 _value,
bytes _data,
uint256 _nonce,
bytes32 _key,
bytes _signature
)
public
keyMessageSigned(
_key,
keccak256(
address(this),
bytes4(keccak256("execute(address,uint256,bytes)")),
_to,
_value,
_data,
_nonce
),
_signature
)
returns (uint256 txId)
{
txId = _execute(_key, _to, _value, _data);
} }
if (totalManagers == 1) { function approveMessageSigned(
delete recoveryManager; uint256 _id,
} bool _approval,
bytes32 _key,
bytes _signature
)
public
keyMessageSigned(
_key,
keccak256(
address(this),
bytes4(keccak256("approve(uint256,bool)")),
_id,
_approval
),
_signature
)
returns (bool success)
{
return _approveRequest(_key, _id, _approval);
} }
////////////////
// Management functions
////////////////
function addKey( function addKey(
bytes32 _key, bytes32 _key,
uint256 _purpose, uint256 _purpose,
@ -162,24 +196,6 @@ contract Identity is ERC725, ERC735, MessageSigned {
return true; return true;
} }
function execute(
address _to,
uint256 _value,
bytes _data
)
public
returns (uint256 txId)
{
txId = _execute(keccak256(msg.sender), _to, _value, _data);
}
function approve(uint256 _id, bool _approval)
public
returns (bool success)
{
return _approveRequest(keccak256(msg.sender), _id, _approval);
}
function setMinimumApprovalsByKeyType( function setMinimumApprovalsByKeyType(
uint256 _purpose, uint256 _purpose,
uint256 _minimumApprovals uint256 _minimumApprovals
@ -192,6 +208,18 @@ contract Identity is ERC725, ERC735, MessageSigned {
purposeThreshold[_purpose] = _minimumApprovals; purposeThreshold[_purpose] = _minimumApprovals;
} }
function setupRecovery(address _recoveryContract)
public
msgSenderKey(MANAGEMENT_KEY)
{
require(recoveryContract == address(0));
recoveryContract = _recoveryContract;
}
////////////////
// Claim related
////////////////
function addClaim( function addClaim(
uint256 _claimType, uint256 _claimType,
uint256 _scheme, uint256 _scheme,
@ -251,6 +279,50 @@ contract Identity is ERC725, ERC735, MessageSigned {
return true; return true;
} }
////////////////
// Recovery methods
////////////////
function managerReset(bytes32 _newKey)
public
recoveryOnly
{
recoveryManager = _newKey;
_addKey(keccak256(recoveryManager), MANAGEMENT_KEY, 0);
purposeThreshold[MANAGEMENT_KEY] = keysByPurpose[MANAGEMENT_KEY].length;
}
function processManagerReset(uint256 _limit)
public
{
require(recoveryManager != 0);
uint256 limit = _limit;
bytes32 newKey = recoveryManager;
bytes32[] memory managers = keysByPurpose[MANAGEMENT_KEY];
uint256 totalManagers = managers.length;
if (limit == 0) {
limit = totalManagers;
}
purposeThreshold[MANAGEMENT_KEY] = totalManagers - limit + 1;
for (uint256 i = 0; i < limit; i++) {
bytes32 manager = managers[i];
if (manager != newKey) {
_removeKey(manager, MANAGEMENT_KEY);
totalManagers--;
}
}
if (totalManagers == 1) {
delete recoveryManager;
}
}
////////////////
// Public Views
////////////////
function getKey( function getKey(
bytes32 _key, bytes32 _key,
uint256 _purpose uint256 _purpose
@ -340,61 +412,9 @@ contract Identity is ERC725, ERC735, MessageSigned {
return claimsByType[_claimType]; return claimsByType[_claimType];
} }
function approveMessageSigned( ////////////////
uint256 _id, // Internal methods
bool _approval, ////////////////
bytes32 _key,
bytes _signature
)
public
keyMessageSigned(
_key,
keccak256(
address(this),
bytes4(keccak256("approve(uint256,bool)")),
_id,
_approval
),
_signature
)
returns (bool success)
{
return _approveRequest(_key, _id, _approval);
}
function executeMessageSigned(
address _to,
uint256 _value,
bytes _data,
uint256 _nonce,
bytes32 _key,
bytes _signature
)
public
keyMessageSigned(
_key,
keccak256(
address(this),
bytes4(keccak256("execute(address,uint256,bytes)")),
_to,
_value,
_data,
_nonce
),
_signature
)
returns (uint256 txId)
{
txId = _execute(_key, _to, _value, _data);
}
function setupRecovery(address _recoveryContract)
public
msgSenderKey(MANAGEMENT_KEY)
{
require(recoveryContract == address(0));
recoveryContract = _recoveryContract;
}
function _constructIdentity(bytes32 _managerKey) function _constructIdentity(bytes32 _managerKey)
internal internal
@ -428,6 +448,24 @@ contract Identity is ERC725, ERC735, MessageSigned {
} }
} }
function _commitCall(
uint256 _txId,
address _to,
uint256 _value,
bytes _data
)
internal
returns(bool success)
{
nonce++;
success = _to.call.value(_value)(_data);
if (success) {
emit Executed(_txId, _to, _value, _data);
} else {
emit ExecutionFailed(_txId, _to, _value, _data);
}
}
function _requestApproval( function _requestApproval(
address _to, address _to,
uint256 _value, uint256 _value,
@ -447,6 +485,10 @@ contract Identity is ERC725, ERC735, MessageSigned {
emit ExecutionRequested(txId, _to, _value, _data); emit ExecutionRequested(txId, _to, _value, _data);
} }
////////////////
// Private methods
////////////////
function _approveRequest( function _approveRequest(
bytes32 _key, bytes32 _key,
uint256 _id, uint256 _id,
@ -478,24 +520,6 @@ contract Identity is ERC725, ERC735, MessageSigned {
multisigTx[_id].approvals[_key] = _approval; multisigTx[_id].approvals[_key] = _approval;
} }
function _commitCall(
uint256 _txId,
address _to,
uint256 _value,
bytes _data
)
internal
returns(bool success)
{
nonce++;
success = _to.call.value(_value)(_data);
if (success) {
emit Executed(_txId, _to, _value, _data);
} else {
emit ExecutionFailed(_txId, _to, _value, _data);
}
}
function _addKey( function _addKey(
bytes32 _key, bytes32 _key,
uint256 _purpose, uint256 _purpose,
@ -570,7 +594,6 @@ contract Identity is ERC725, ERC735, MessageSigned {
); );
} }
function _modifyClaim( function _modifyClaim(
bytes32 _claimHash, bytes32 _claimHash,
uint256 _claimType, uint256 _claimType,