The goal of ComplyDeFi is to provide a simple contract to transform a permissionless DeFi protocol into a permissioned DeFi protocol. To do so, ComplyDeFi is leveraging the power of the ONCHAINID protocol, an open source & decentralized system providing identity smart contracts based on the implementation of ERC734 and ERC735. ComplyDeFi provides a very simple modifier that has to be added on the functions that require permissioning to ensure the caller of this function is eligible following the rules that the owner of the DeFi contract required.
ComplyDeFi uses several concepts to work properly, these concepts are defined hereunder :
First of all, the primary need of ComplyDeFi is to know who is managing the wallets interacting with the protocol,
or at least know that the user behind this wallet has an ONCHAINID and is eligible following the claim requirements.
For that purpose, the ComplyDeFi contract needs to have access to the ONCHAINID address corresponding to any wallet
trying to interact with it. The function used to do that is getIdentity
that is available on the ONCHAINID Factory.
The link to the ONCHAINID Factory is therefore a critical point on any ComplyDeFi contract, that's why it is
mandatory to give the address of the Factory contract in the constructor of any contract inheriting from ComplyDeFi.
If the address was not set properly, it is still possible to fix it with the setFactory
function available on the
ComplyDeFi interface, this function can be called only by the contract owner obviously, as it is a critical function.
The Claim Issuers are defined on the ONCHAINID protocol, basically Claim issuers are ONCHAINID contracts that are designed to emit claims for other ONCHAINIDs, they have the power to revoke a claim that they issued previously to remove the eligibility of an ONCHAINID. Claim Issuers can be any trusted third party that the protocol owner needs to verify the eligibility of its users, e.g. KYC providers, AML services, ...
The owner of the ComplyDeFi protocol has the possibility to customize the claim requirements for granting access to the DeFi protocol by designating trusted issuers and required claims.
The onlyComply
modifier is used to add the permissioning layer on top of an existing function from the permissionless DeFi smart contracts. The contract simply needs to inherit from ComplyDeFi, see the code example below, in this code the well known gooseDeFi protocol is turned into a permissioned DeFi protocol thanks to ComplyDeFi by adding a permission layer on the deposit
function that is used to stake funds on the contract. In this case, the deposit of funds will be allowed only if the wallet that is used for the deposit is linked to a valid ONCHAINID, deployed by the ONCHAINID Factory, and containing the valid claims, required by the protocol and issued by trusted third parties approved by the DeFi protocol owner.
import "gooseFinance/MasterChef.sol";
import "ComplyDeFi.sol";
contract GooseComply is MasterChef, ComplyDeFi {
constructor (
address _factory,
address _id,
EggToken _egg,
address _devaddr,
address _feeAddress,
uint256 _eggPerBlock,
uint256 _startBlock)
ComplyDeFi(_factory, _id)
MasterChef(_egg, _devaddr, _feeAddress, _eggPerBlock, _startBlock) {
}
function deposit(uint256 _pid, uint256 _amount) public override onlyComply {
super.deposit(_pid, _amount);
}
}