Partially completed MoatAddress and MoatAsset contracts.

This commit is contained in:
Sowmayjain 2018-10-24 22:42:07 +05:30
parent bc56f97700
commit 6428bfa76f
5 changed files with 169 additions and 0 deletions

33
contracts/MoatAddress.sol Normal file
View File

@ -0,0 +1,33 @@
// Implement the proper governance mechanism to update the addresses
pragma solidity ^0.4.24;
contract AddressRegistry {
event eSetAddr(string AddrName, address TargetAddr);
mapping(bytes32 => address) internal addressBook;
modifier onlyAdmin() {
require(
msg.sender == getAddr("admin"),
"Permission Denied"
);
_;
}
constructor() public {
addressBook[keccak256("admin")] = msg.sender;
}
function setAddr(string AddrName, address Addr) public onlyAdmin {
addressBook[keccak256(AddrName)] = Addr;
emit eSetAddr(AddrName, Addr);
}
function getAddr(string AddrName) public view returns(address AssignedAddress) {
address realAddress = addressBook[keccak256(AddrName)];
require(realAddress != address(0), "Not a valid address.");
return realAddress;
}
}

128
contracts/MoatAsset.sol Normal file
View File

@ -0,0 +1,128 @@
// Allow ERC20 deposits
// withdraw the extra assets other than global balance (in case anyone donated for free) and then no need for seperate brokerage calculation
pragma solidity ^0.4.24;
interface AddressRegistry {
function getAddr(string AddrName) external returns(address);
}
interface token {
function approve(address spender, uint256 value) external returns (bool);
function transfer(address receiver, uint amount) external returns (bool);
}
contract Registry {
address public registryAddress;
modifier onlyAdmin() {
require(
msg.sender == getAddress("admin"),
"Permission Denied"
);
_;
}
function getAddress(string AddressName) internal view returns(address) {
AddressRegistry aRegistry = AddressRegistry(registryAddress);
address realAddress = aRegistry.getAddr(AddressName);
require(realAddress != address(0), "Invalid Address");
return realAddress;
}
}
contract AllowedResolver is Registry {
// Contract Address >> Asset Owner Address >> Bool
mapping(address => mapping(address => bool)) allowed;
bool public ACEnabled;
modifier onlyAllowedResolver() {
require(
allowed[getAddress("resolver")][msg.sender],
"Permission Denied"
);
_;
}
// only the contracts allowed for asset owners can withdraw assets and update balance on behalf
function allowContract() public {
allowed[getAddress("resolver")][msg.sender] = true;
}
function disallowContract() public {
allowed[getAddress("resolver")][msg.sender] = false;
}
// enableAC & disableAC will completely stop the withdrawal of assets on behalf (additional security check)
function enableAC() public onlyAdmin {
ACEnabled = true;
}
function disableAC() public onlyAdmin {
ACEnabled = false;
}
}
contract MoatAsset is AllowedResolver {
// AssetOwner >> TokenAddress >> Balance (as per respective decimals)
mapping(address => mapping(address => uint)) Balances;
address ETH = 0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee;
function getBalance(
address AssetHolder,
address Token
) public view returns (uint256 balance) {
return Balances[AssetHolder][Token];
}
// received ether directly from protocols like Kyber Network
function () public payable {}
function Deposit() public payable {
Balances[msg.sender][ETH] += msg.value;
}
function Withdraw(
address addr,
uint amt
) public {
require(Balances[msg.sender][addr] >= amt, "Insufficient Balance");
Balances[msg.sender][addr] -= amt;
if (addr == ETH) {
msg.sender.transfer(amt);
} else {
token tokenFunctions = token(addr);
tokenFunctions.transfer(msg.sender, amt);
}
}
function UpdateBalance(
address tokenAddr,
uint amt,
bool add,
address target
) public onlyAllowedResolver {
if (add) {
Balances[target][tokenAddr] += amt;
} else {
Balances[target][tokenAddr] -= amt;
}
}
function TransferAssets(
address tokenAddress,
uint amount,
address sendTo
) public onlyAllowedResolver {
if (tokenAddress == ETH) {
sendTo.transfer(amount);
} else {
token tokenFunctions = token(tokenAddress);
tokenFunctions.transfer(sendTo, amount);
}
}
constructor(address rAddr) public {
registryAddress = rAddr;
enableAC();
}
}

View File

@ -0,0 +1,3 @@
// withdraw store the 0.5% on the contract itself and can be withdrawn by admin addresses
// this is the logic contract - stores nothing
// https://bitbucket.org/Sowmay/resolver-dex/src/master/contracts/MoatResolver.sol

View File

@ -0,0 +1,2 @@
// Kyber Network Integration
// https://github.com/cryptoPay-ETHSF/SmartContract/blob/master/CryptoPayRopsten.sol

View File

@ -0,0 +1,3 @@
// MakerDAO integration
// https://github.com/cryptoPay-ETHSF/SmartContract/blob/master/CryptoPayKovan.sol
// this contract will be the owner of all the CDPs, upgrading this means all the data need to be migrated