Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x55c75414F525Ef9ccbb8105Ce083EDbDA0075FB5
Balance 0 ETH
Nonce 1
Code Size 13395 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

13395 bytes
0x608060405234801561001057600080fd5b50600436106102955760003560e01c8063792b55b611610167578063c4d66de8116100ce578063f39c38a011610087578063f39c38a01461052c578063f58c251c14610534578063fc00e8a01461053c578063fc0c546a1461054f578063fefdc5d114610557578063ff50abdc1461056a57610295565b8063c4d66de8146104c5578063ce5494bb146104d8578063d8aed145146104eb578063ddc63262146104fe578063ec38a86214610511578063f0d787a31461052457610295565b8063a7c6a10011610120578063a7c6a10014610469578063aa6e043414610471578063aaf1666014610484578063adb4a9ad14610497578063b5962917146104aa578063b6b55f25146104b257610295565b8063792b55b61461040d5780639a9af221146104205780639ec5a89414610433578063a005fda31461043b578063a0712d6814610443578063a1e401a91461045657610295565b8063415f12401161020b57806353ffa18b116101c457806353ffa18b146103c75780635641ec03146103da5780635a9b5e92146103e25780635aa6e675146103f55780636b9f96ea146103fd5780637239d2b91461040557610295565b8063415f12401461036957806345ee07551461037c57806345f867b31461038f5780634aaf7c65146103975780634c3a8e02146103ac578063538ba4f9146103bf57610295565b806322c37b751161025d57806322c37b751461030a578063238efcbc1461031d5780632670fdd8146103255780632e1a7d4d1461033857806330d4d190146103595780633847f0381461036157610295565b80630510111e1461029a57806309dac061146102b85780630abb6035146102cd578063158ef93e146102e05780631718a68f146102f5575b600080fd5b6102a2610572565b6040516102af9190613346565b60405180910390f35b6102cb6102c6366004612a0e565b61057e565b005b6102cb6102db366004612a0e565b61062d565b6102e86106c8565b6040516102af9190612b8a565b6102fd6106d1565b6040516102af9190612b16565b6102cb610318366004612ac1565b6106e0565b6102cb61070f565b6102fd610333366004612ac1565b61078a565b61034b610346366004612ac1565b6107a9565b6040516102af92919061334f565b6102a2610937565b6102a2610943565b61034b610377366004612ac1565b610949565b6102cb61038a366004612a55565b610b31565b6102a2610bb3565b61039f610bb9565b6040516102af919061333c565b61034b6103ba366004612ac1565b610bd5565b6102fd610c4f565b6102cb6103d5366004612ac1565b610c54565b6102e8610d0e565b6102cb6103f0366004612a2a565b610d1c565b6102fd610d6c565b6102a2610d7b565b6102fd610e01565b6102cb61041b366004612ac1565b610e10565b6102a261042e366004612a0e565b610e91565b6102fd610eaf565b6102fd610ebe565b6102cb610451366004612ac1565b610ecd565b6102a2610464366004612a0e565b6110ee565b6102a2611109565b6102a261047f366004612a0e565b61111a565b6102a2610492366004612ac1565b611144565b6102cb6104a5366004612a0e565b61115d565b6102a26111f8565b6102cb6104c0366004612ac1565b6111fe565b6102cb6104d3366004612a0e565b61134d565b6102cb6104e6366004612a0e565b611403565b6102cb6104f9366004612ad9565b61145b565b61034b61050c366004612ac1565b611710565b6102cb61051f366004612a0e565b611849565b6102a26118e4565b6102fd6118ea565b6102fd6118f9565b6102a261054a366004612a0e565b611908565b6102fd61192b565b61034b610565366004612ad9565b61193a565b6102a2611991565b673782dace9d90000081565b6003546001600160a01b031633146105b15760405162461bcd60e51b81526004016105a890612c15565b60405180910390fd5b6001600160a01b0381166105d75760405162461bcd60e51b81526004016105a890612bc8565b600580546001600160a01b0319166001600160a01b0383161790556040517fdc117600f93282860144d2cd2745f8e2e15c3ca2a32b4290c30f7cd1ae7ffcb990610622908390612b16565b60405180910390a150565b6003546001600160a01b031633146106575760405162461bcd60e51b81526004016105a890612c15565b6001600160a01b03811661067d5760405162461bcd60e51b81526004016105a8906130b5565b600480546001600160a01b0319166001600160a01b0383161790556040517fc9e2377236eab4280090ce8f2317332649736d92f00dcf20a8dd6684ec5e783990610622908390612b16565b600b5460ff1681565b6002546001600160a01b031681565b6003546001600160a01b0316331461070a5760405162461bcd60e51b81526004016105a890612c15565b600a55565b6004546001600160a01b031633146107395760405162461bcd60e51b81526004016105a89061307e565b600454600380546001600160a01b0319166001600160a01b0390921691821790556040517f9d3e522e1e47a2f6009739342b9cc7b252a1888154e843ab55ee1c81745795ab90610622908390612b16565b600080610798600f846119da565b546001600160a01b03169392505050565b600080600260005414156107cf5760405162461bcd60e51b81526004016105a8906132d9565b60026000556107dd33611a01565b1580156107e957503332145b6108055760405162461bcd60e51b81526004016105a890612cd4565b600b5460ff166108275760405162461bcd60e51b81526004016105a890613217565b336000908152600e60205260409020600381015443116108595760405162461bcd60e51b81526004016105a890613198565b61086481600c611a07565b6000806108713387611a63565b60408051808201909152601b81527f4578636565647320776974686472617761626c6520616d6f756e740000000000602082015285549294509092506108b991908390611b8d565b8355604080516060810190915260318082526108e291600c916133ed6020830139859190611bb9565b336001600160a01b03167fb3ad69dc1d2c6b1f5f5b0927ffd8ee8f1437a156253c8f6dccc75e6f8e4fd38b87848460405161091f9392919061335d565b60405180910390a26001600055909590945092505050565b670de0b6b3a764000081565b60115481565b6000806002600054141561096f5760405162461bcd60e51b81526004016105a8906132d9565b600260005561097d33611a01565b15801561098957503332145b6109a55760405162461bcd60e51b81526004016105a890612cd4565b60115415610a4f57601054604080516350d25bcd60e01b815290516000926001600160a01b0316916350d25bcd916004808301926020929190829003018186803b1580156109f257600080fd5b505afa158015610a06573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a2a9190612aa9565b90506011548111610a4d5760405162461bcd60e51b81526004016105a890613310565b505b600b5460ff16610a715760405162461bcd60e51b81526004016105a890613217565b336000908152600e60205260409020610a8b81600c611a07565b8060010154841115610a9f57806001015493505b600080610aac3087611a63565b91509150610ab982611be8565b6040805160208101909152600081528354610ad5918390611b8d565b83556040805160208101909152600081526001840154610af6918490611b8d565b600184015560405133907f3ea051727656be6fd11c2260f244f29ff3c70d1fb077bfa73e89d554e9bb95c79061091f9089908690869061335d565b6003546001600160a01b0316331480610b5457506005546001600160a01b031633145b610b705760405162461bcd60e51b81526004016105a890613198565b600b805461ff001916610100831515021790556040517ff0064f2efd0da4bc63eecf2e75590fe8a308eaa526a51c334e50eec09a71104990610622908390612b8a565b61271081565b610bc16129fb565b506040805160208101909152600c54815290565b60008060026000541415610bfb5760405162461bcd60e51b81526004016105a8906132d9565b6002600055600b5460ff16610c225760405162461bcd60e51b81526004016105a890613217565b6000610c2f600f856119da565b9050610c3f848260010154611d3a565b6001600055909590945092505050565b600081565b6003546001600160a01b03163314610c7e5760405162461bcd60e51b81526004016105a890612c15565b670de0b6b3a7640000811015610ca65760405162461bcd60e51b81526004016105a890612f4a565b673782dace9d900000811115610cce5760405162461bcd60e51b81526004016105a890612e99565b60408051602081018252829052600c829055517ff78180bc708b1292177c888900951cd66a39faf48dc7b6d111e93285dbbe55a090610622908390613346565b600b54610100900460ff1681565b6003546001600160a01b03163314610d465760405162461bcd60e51b81526004016105a890612c15565b601080546001600160a01b0319166001600160a01b039390931692909217909155601155565b6003546001600160a01b031681565b600060026000541415610da05760405162461bcd60e51b81526004016105a8906132d9565b6002600055600b5460ff16610dc75760405162461bcd60e51b81526004016105a890613217565b600b54610100900460ff1615610def5760405162461bcd60e51b81526004016105a8906131a9565b610df7611df7565b9050600160005590565b6006546001600160a01b031681565b6003546001600160a01b03163314610e3a5760405162461bcd60e51b81526004016105a890612c15565b612710811115610e5c5760405162461bcd60e51b81526004016105a890613104565b60088190556040517fc36862a253ff42cc71f4f200d3c62e8e5eaaece01041fc6900aeace64ade72a890610622908390613346565b6001600160a01b03166000908152600e602052604090206003015490565b6007546001600160a01b031681565b6010546001600160a01b031681565b60026000541415610ef05760405162461bcd60e51b81526004016105a8906132d9565b6002600055610efe33611a01565b158015610f0a57503332145b610f265760405162461bcd60e51b81526004016105a890612cd4565b60115415610fd057601054604080516350d25bcd60e01b815290516000926001600160a01b0316916350d25bcd916004808301926020929190829003018186803b158015610f7357600080fd5b505afa158015610f87573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610fab9190612aa9565b90506011548111610fce5760405162461bcd60e51b81526004016105a890613310565b505b600b5460ff16610ff25760405162461bcd60e51b81526004016105a890613217565b336000908152600e6020526040902061100c81600c611a07565b6002810154828110156110705760006110258483611e50565b60018401549091506110379082611e78565b6001840155600060028401556040805160608101909152602a80825261106a91600c916133c36020830139859190611bb9565b50611080565b61107a8184611e50565b60028301555b6002546040516340c10f1960e01b81526001600160a01b03909116906340c10f19906110b29033908790600401612b2a565b600060405180830381600087803b1580156110cc57600080fd5b505af11580156110e0573d6000803e3d6000fd5b505060016000555050505050565b6001600160a01b03166000908152600e602052604090205490565b6000611115600f611e9d565b905090565b6001600160a01b0381166000908152600e6020526040812061113d81600c611ea1565b9392505050565b600080611152600f846119da565b600101549392505050565b6003546001600160a01b031633146111875760405162461bcd60e51b81526004016105a890612c15565b6001600160a01b0381166111ad5760405162461bcd60e51b81526004016105a890612d09565b600680546001600160a01b0319166001600160a01b0383161790556040517fe42bb1780117f5788c6e0042e955291223819875891ddf465b8e4fbb85a933e990610622908390612b16565b60085481565b600260005414156112215760405162461bcd60e51b81526004016105a8906132d9565b600260005561122f33611a01565b15801561123b57503332145b6112575760405162461bcd60e51b81526004016105a890612cd4565b600b5460ff166112795760405162461bcd60e51b81526004016105a890613217565b600b54610100900460ff16156112a15760405162461bcd60e51b81526004016105a8906131a9565b336000908152600e602052604090206112bb81600c611a07565b6001546112d3906001600160a01b0316333085611ee0565b600a5482106112e6576112e4611df7565b505b6009546112f39083611e78565b60095580546113029083611e78565b815543600382015560405133907f59062170a285eb80e8c6b8ced60428442a51910635005233fc4ce084a475845e9061133c908590613346565b60405180910390a250506001600055565b6003546001600160a01b031633146113775760405162461bcd60e51b81526004016105a890612c15565b600b5460ff161561139a5760405162461bcd60e51b81526004016105a890613298565b6006546001600160a01b03166113c25760405162461bcd60e51b81526004016105a890612eed565b6007546001600160a01b03166113ea5760405162461bcd60e51b81526004016105a890612e0c565b6113f381611f38565b50600b805460ff19166001179055565b600b5460ff166114255760405162461bcd60e51b81526004016105a890613217565b6003546001600160a01b0316331461144f5760405162461bcd60e51b81526004016105a890612c15565b61145881611f38565b50565b6002600054141561147e5760405162461bcd60e51b81526004016105a8906132d9565b600260005561148c33611a01565b15801561149857503332145b6114b45760405162461bcd60e51b81526004016105a890612cd4565b6011541561155e57601054604080516350d25bcd60e01b815290516000926001600160a01b0316916350d25bcd916004808301926020929190829003018186803b15801561150157600080fd5b505afa158015611515573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906115399190612aa9565b9050601154811161155c5760405162461bcd60e51b81526004016105a890613310565b505b600b5460ff166115805760405162461bcd60e51b81526004016105a890613217565b336000908152600e6020526040902061159a81600c611a07565b82156115c1576001546115b8906001600160a01b0316333086611ee0565b6115c183611be8565b811561168e5760025460405163079cc67960e41b81526001600160a01b03909116906379cc6790906115f99033908690600401612b2a565b600060405180830381600087803b15801561161357600080fd5b505af1158015611627573d6000803e3d6000fd5b505060025460405163288aafcb60e01b81526001600160a01b03909116925063288aafcb915061165b908590600401613346565b600060405180830381600087803b15801561167557600080fd5b505af1158015611689573d6000803e3d6000fd5b505050505b600061169a8484611e78565b90506116c481604051806020016040528060008152508460010154611b8d9092919063ffffffff16565b600183015560405133907fbade234341a40ca3c71df59b3ca02b8bb65b491a098af970953228b4f4a5d38f906116fd908790879061334f565b60405180910390a2505060016000555050565b600b54600090819060ff166117375760405162461bcd60e51b81526004016105a890613217565b6000611744600f856119da565b90506000806117538330612063565b9092509050811561180557600061178161271061177b6008548661199790919063ffffffff16565b9061207e565b9050600061178f8483611e50565b90506117996129fb565b6117ae6009546117a8846120b0565b906120f2565b6040805160208101909152600d5481529091506117cb9082612126565b51600d5582156117f2576007546001546117f2916001600160a01b03918216911685612156565b81156118015761180182611be8565b5050505b7f11d2034f4471d11a13f0f1798ceaf0c9db2812d450a0681958ce7d4f2fb97f09828260405161183692919061334f565b60405180910390a1909350915050915091565b6003546001600160a01b031633146118735760405162461bcd60e51b81526004016105a890612c15565b6001600160a01b0381166118995760405162461bcd60e51b81526004016105a89061314c565b600780546001600160a01b0319166001600160a01b0383161790556040517f05f3326e0527f309d4015dee3bc3f36e650b53fc823bab69c99847814acfafdf90610622908390612b16565b600a5481565b6004546001600160a01b031681565b6005546001600160a01b031681565b6001600160a01b0381166000908152600e6020526040812061113d81600c61217a565b6001546001600160a01b031681565b600080600260005414156119605760405162461bcd60e51b81526004016105a8906132d9565b6002600055600b5460ff166119875760405162461bcd60e51b81526004016105a890613217565b610c3f8484611d3a565b60095481565b6000826119a6575060006119d4565b828202828482816119b357fe5b04146119d15760405162461bcd60e51b81526004016105a89061303d565b90505b92915050565b60008260000182815481106119eb57fe5b9060005260206000209060020201905092915050565b3b151590565b6000611a1383836121c1565b90508260010154811115611a41576001830180546000909155611a368282611e50565b600285015550611a56565b6001830154611a509082611e50565b60018401555b5060010154600490910155565b6001546040516370a0823160e01b815260009182918291611af39186916001600160a01b0316906370a0823190611a9e903090600401612b16565b60206040518083038186803b158015611ab657600080fd5b505afa158015611aca573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611aee9190612aa9565b61223a565b90506001600160a01b0385163014611b1c57600154611b1c906001600160a01b03168683612156565b80806000611b2a8783611e50565b90508015611b70576000611b3e600f612250565b9050600080611b4f838c868461227b565b9092509050611b5e8683611e78565b9550611b6a8582611e78565b94505050505b600954611b7d9083611e50565b6009555090969095509350505050565b60008184841115611bb15760405162461bcd60e51b81526004016105a89190612b95565b505050900390565b611bc383836122b4565b8190611be25760405162461bcd60e51b81526004016105a89190612b95565b50505050565b60015460065460405163095ea7b360e01b81526001600160a01b039283169263095ea7b392611c1e929116908590600401612b2a565b602060405180830381600087803b158015611c3857600080fd5b505af1158015611c4c573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611c709190612a71565b50600654604051631f72642160e31b81526001600160a01b039091169063fb93210890611ca39030908590600401612b2a565b600060405180830381600087803b158015611cbd57600080fd5b505af1158015611cd1573d6000803e3d6000fd5b505060025460405163288aafcb60e01b81526001600160a01b03909116925063288aafcb9150611d05908490600401613346565b600060405180830381600087803b158015611d1f57600080fd5b505af1158015611d33573d6000803e3d6000fd5b5050505050565b600b546000908190610100900460ff1680611d5f57506003546001600160a01b031633145b80611d735750611d6f600f6122e2565b8414155b611d8f5760405162461bcd60e51b81526004016105a890612f9e565b6000611d9c600f866119da565b9050600080611dad8330888461227b565b91509150867fccbd929f935422b28ee209a0db0556280b0a3d9bc4da58f1d3f0ab4f8a4996478383604051611de392919061334f565b60405180910390a290969095509350505050565b600080611e04600f612250565b90506000611e118261232f565b90507f860f4701faa0ecdeecd9e9eaae11a8612bbd01c663081f7c0c4e4873df653d6981604051611e429190613346565b60405180910390a191505090565b600082821115611e725760405162461bcd60e51b81526004016105a890612d58565b50900390565b6000828201838110156119d15760405162461bcd60e51b81526004016105a890612c4c565b5490565b600080611eae84846121c1565b905080611ec157505060018201546119d4565b6001840154808210611ed8576000925050506119d4565b039392505050565b611be2846323b872dd60e01b858585604051602401611f0193929190612b43565b60408051601f198184030181529190526020810180516001600160e01b03166001600160e01b0319909316929092179091526123c3565b6001600160a01b038116611f5e5760405162461bcd60e51b81526004016105a890612c83565b60015460408051637e062a3560e11b815290516001600160a01b039283169284169163fc0c546a916004808301926020929190829003018186803b158015611fa557600080fd5b505afa158015611fb9573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611fdd9190612a8d565b6001600160a01b0316146120035760405162461bcd60e51b81526004016105a890612dd5565b604080518082019091526001600160a01b03821681526000602082015261202c90600f90612452565b6040516001600160a01b038216907f0821015de34e20b0878a40f6f165801417f53b2017016d7321cacee989c8cfa790600090a250565b6000806120738484836001612495565b915091509250929050565b600080821161209f5760405162461bcd60e51b81526004016105a890612e62565b8183816120a857fe5b049392505050565b6120b86129fb565b60008215806120d5575050670de0b6b3a764000082810290810483145b6120de57600080fd5b604080516020810190915290815292915050565b6120fa6129fb565b8161210457600080fd5b60405180602001604052808385600001518161211c57fe5b0490529392505050565b61212e6129fb565b8251825181019081101561214157600080fd5b60408051602081019091529081529392505050565b6121758363a9059cbb60e01b8484604051602401611f01929190612b2a565b505050565b60008061218784846121c1565b90508061219a57505060028201546119d4565b60018401548082116121b1576000925050506119d4565b6002850154910301905092915050565b60006121cb6129fb565b506040805160208101909152600183015481526121e66129fb565b50604080516020810190915260048501548152612203828261266a565b612212576000925050506119d4565b84546122319061222c90612226858561269b565b906126b6565b6126e4565b95945050505050565b600081831061224957816119d1565b5090919050565b60008161225c816122e2565b8154811061226657fe5b90600052602060002090600202019050919050565b600080808061228c88888888612495565b60018a015491935091506122a09082611e50565b600189015590925090505b94509492505050565b6000806122d96122c485856126f3565b6040805160208101909152855481529061266a565b13159392505050565b6000806122ee83611e9d565b905061113d6001604051806040016040528060118152602001705661756c742e4c6973743a20656d70747960781b81525083611b8d9092919063ffffffff16565b60008061233b83612737565b905061113d816001600160a01b03166370a08231306040518263ffffffff1660e01b815260040161236c9190612b16565b60206040518083038186803b15801561238457600080fd5b505afa158015612398573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906123bc9190612aa9565b84906127b3565b6060612418826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b031661285a9092919063ffffffff16565b80519091501561217557808060200190518101906124369190612a71565b6121755760405162461bcd60e51b81526004016105a89061324e565b8154600180820184556000938452602093849020835160029093020180546001600160a01b0319166001600160a01b039093169290921782559190920151910155565b60008060006124a387612737565b90506000816001600160a01b03166370a08231886040518263ffffffff1660e01b81526004016124d39190612b16565b60206040518083038186803b1580156124eb57600080fd5b505afa1580156124ff573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906125239190612aa9565b9050600061253089612869565b895460405163ead5d35960e01b81529192506001600160a01b03169063ead5d35990612564908b908b908b90600401612b67565b600060405180830381600087803b15801561257e57600080fd5b505af1158015612592573d6000803e3d6000fd5b50506040516370a0823160e01b8152600092506001600160a01b03861691506370a08231906125c5908c90600401612b16565b60206040518083038186803b1580156125dd57600080fd5b505afa1580156125f1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906126159190612aa9565b905060006126238285611e50565b905060006126308c612869565b9050600061263e8583611e50565b905089156126595782600098509850505050505050506122ab565b9197509095506122ab945050505050565b80518251600091111561268057506000196119d4565b815183511115612692575060016119d4565b50600092915050565b6126a36129fb565b8251825181039081111561214157600080fd5b6126be6129fb565b60008215806126db5750508251828102908382816126d857fe5b04145b61214157600080fd5b51670de0b6b3a7640000900490565b6126fb6129fb565b60006127078484611ea1565b90508061271e576127166128e5565b9150506119d4565b61272f816117a886600001546120b0565b949350505050565b805460408051637e062a3560e11b815290516000926001600160a01b03169163fc0c546a916004808301926020929190829003018186803b15801561277b57600080fd5b505afa15801561278f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119d49190612a8d565b6000806127bf84612737565b84549091506127db906001600160a01b03808416911685612156565b835460405163b6b55f2560e01b81526001600160a01b039091169063b6b55f259061280a908690600401613346565b600060405180830381600087803b15801561282457600080fd5b505af1158015612838573d6000803e3d6000fd5b505050600185015461284b915084611e78565b60018501555081905092915050565b606061272f8484600085612901565b8054604080516306a61f7560e51b815290516000926001600160a01b03169163d4c3eea0916004808301926020929190829003018186803b1580156128ad57600080fd5b505afa1580156128c1573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119d49190612aa9565b6128ed6129fb565b506040805160208101909152600019815290565b6060824710156129235760405162461bcd60e51b81526004016105a890612d8f565b61292c85611a01565b6129485760405162461bcd60e51b81526004016105a8906131e0565b60006060866001600160a01b031685876040516129659190612afa565b60006040518083038185875af1925050503d80600081146129a2576040519150601f19603f3d011682016040523d82523d6000602084013e6129a7565b606091505b50915091506129b78282866129c2565b979650505050505050565b606083156129d157508161113d565b8251156129e15782518084602001fd5b8160405162461bcd60e51b81526004016105a89190612b95565b6040518060200160405280600081525090565b600060208284031215612a1f578081fd5b81356119d18161339f565b60008060408385031215612a3c578081fd5b8235612a478161339f565b946020939093013593505050565b600060208284031215612a66578081fd5b81356119d1816133b4565b600060208284031215612a82578081fd5b81516119d1816133b4565b600060208284031215612a9e578081fd5b81516119d18161339f565b600060208284031215612aba578081fd5b5051919050565b600060208284031215612ad2578081fd5b5035919050565b60008060408385031215612aeb578182fd5b50508035926020909101359150565b60008251612b0c818460208701613373565b9190910192915050565b6001600160a01b0391909116815260200190565b6001600160a01b03929092168252602082015260400190565b6001600160a01b039384168152919092166020820152604081019190915260600190565b6001600160a01b0393909316835260208301919091521515604082015260600190565b901515815260200190565b6000602082528251806020840152612bb4816040850160208701613373565b601f01601f19169190910160400192915050565b6020808252602d908201527f59756d4c5553445661756c743a2073656e74696e656c2061646472657373206360408201526c30b73737ba10313290183c181760991b606082015260800190565b6020808252601e908201527f59756d4c5553445661756c743a206f6e6c7920676f7665726e616e63652e0000604082015260600190565b6020808252601b908201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604082015260600190565b60208082526031908201527f59756d4c5553445661756c743a20616374697665207661756c7420616464726560408201527039b99031b0b73737ba10313290183c181760791b606082015260800190565b6020808252818101527f536f72727920776520646f206e6f742061636365707420636f6e747261637421604082015260600190565b6020808252602f908201527f59756d4c5553445661756c743a207472616e736d75746572206164647265737360408201526e1031b0b73737ba10313290183c181760891b606082015260800190565b6020808252601e908201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604082015260600190565b60208082526026908201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6040820152651c8818d85b1b60d21b606082015260800190565b6020808252601d908201527f59756d4c5553445661756c743a20746f6b656e206d69736d617463682e000000604082015260600190565b60208082526036908201527f59756d4c5553445661756c743a2063616e6e6f7420696e697469616c697a6520604082015275072657761726473206164647265737320746f203078360541b606082015260800190565b6020808252601a908201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604082015260600190565b60208082526034908201527f59756d4c5553445661756c743a20636f6c6c61746572616c697a6174696f6e206040820152733634b6b4ba1030b137bb329036b0bc34b6bab69760611b606082015260800190565b60208082526039908201527f59756d4c5553445661756c743a2063616e6e6f7420696e697469616c697a652060408201527f7472616e736d75746572206164647265737320746f2030783000000000000000606082015260800190565b60208082526034908201527f59756d4c5553445661756c743a20636f6c6c61746572616c697a6174696f6e206040820152733634b6b4ba103132b637bb9036b4b734b6bab69760611b606082015260800190565b60208082526073908201527f59756d4c5553445661756c743a206e6f7420616e20656d657267656e63792c2060408201527f6e6f7420676f7665726e616e63652c20616e64207573657220646f6573206e6f60608201527f742068617665207065726d697373696f6e20746f20726563616c6c2066756e646080820152721cc8199c9bdb481858dd1a5d99481d985d5b1d606a1b60a082015260c00190565b60208082526021908201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6040820152607760f81b606082015260800190565b6020808252601f908201527f73656e646572206973206e6f742070656e64696e67476f7665726e616e636500604082015260600190565b6020808252602f908201527f59756d4c5553445661756c743a20676f7665726e616e6365206164647265737360408201526e1031b0b73737ba10313290183c181760891b606082015260800190565b60208082526028908201527f59756d4c5553445661756c743a2068617276657374206665652061626f76652060408201526736b0bc34b6bab69760c11b606082015260800190565b6020808252602c908201527f59756d4c5553445661756c743a2072657761726473206164647265737320636160408201526b373737ba10313290183c181760a11b606082015260800190565b602080825260009082015260400190565b60208082526017908201527f656d657267656e637920706175736520656e61626c6564000000000000000000604082015260600190565b6020808252601d908201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604082015260600190565b6020808252601e908201527f59756d4c5553445661756c743a206e6f7420696e697469616c697a65642e0000604082015260600190565b6020808252602a908201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6040820152691bdd081cdd58d8d9595960b21b606082015260800190565b60208082526021908201527f59756d4c5553445661756c743a20616c726561647920696e697469616c697a656040820152601960fa1b606082015260800190565b6020808252601f908201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604082015260600190565b60208082526012908201527137b333103832b3903634b6b4ba30ba34b7b760711b604082015260600190565b9051815260200190565b90815260200190565b918252602082015260400190565b9283526020830191909152604082015260600190565b60005b8381101561338e578181015183820152602001613376565b83811115611be25750506000910152565b6001600160a01b038116811461145857600080fd5b801515811461145857600080fdfe59756d4c5553445661756c743a204c6f616e2d746f2d76616c756520726174696f206272656163686564416374696f6e20626c6f636b65643a20756e6865616c74687920636f6c6c61746572616c697a6174696f6e20726174696fa2646970667358221220afa1a46ade836f938bede509ad2666413baa384b40ade08bfb86922280f42fcb64736f6c634300060c0033

Verified Source Code Full Match

Compiler: v0.6.12+commit.27d51765 EVM: istanbul Optimization: Yes (200 runs)
yumlusd.sol 3378 lines
// Sources flattened with hardhat v2.1.1 https://hardhat.org

// File @openzeppelin/contracts/math/[email protected]

// SPDX-License-Identifier: MIT

pragma solidity >=0.6.0 <0.8.0;

/**
 * @dev Standard math utilities missing in the Solidity language.
 */
library Math {
    /**
     * @dev Returns the largest of two numbers.
     */
    function max(uint256 a, uint256 b) internal pure returns (uint256) {
        return a >= b ? a : b;
    }

    /**
     * @dev Returns the smallest of two numbers.
     */
    function min(uint256 a, uint256 b) internal pure returns (uint256) {
        return a < b ? a : b;
    }

    /**
     * @dev Returns the average of two numbers. The result is rounded towards
     * zero.
     */
    function average(uint256 a, uint256 b) internal pure returns (uint256) {
        // (a + b) / 2 can overflow, so we distribute
        return (a / 2) + (b / 2) + ((a % 2 + b % 2) / 2);
    }
}


// File @openzeppelin/contracts/utils/[email protected]

pragma solidity >=0.6.0 <0.8.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor () internal {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
}


// File @openzeppelin/contracts/utils/[email protected]

pragma solidity >=0.6.2 <0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: value }(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}


// File @openzeppelin/contracts/token/ERC20/[email protected]

pragma solidity >=0.6.0 <0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}


// File @openzeppelin/contracts/math/[email protected]

pragma solidity >=0.6.0 <0.8.0;

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        uint256 c = a + b;
        if (c < a) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the substraction of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b > a) return (false, 0);
        return (true, a - b);
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     *
     * _Available since v3.4._
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) return (true, 0);
        uint256 c = a * b;
        if (c / a != b) return (false, 0);
        return (true, c);
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a / b);
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     *
     * _Available since v3.4._
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        if (b == 0) return (false, 0);
        return (true, a % b);
    }

    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");
        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) return 0;
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: modulo by zero");
        return a % b;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        return a - b;
    }

    /**
     * @dev Returns the integer division of two unsigned integers, reverting with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryDiv}.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * reverting with custom message when dividing by zero.
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {tryMod}.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        return a % b;
    }
}


// File @openzeppelin/contracts/token/ERC20/[email protected]

pragma solidity >=0.6.0 <0.8.0;



/**
 * @title SafeERC20
 * @dev Wrappers around ERC20 operations that throw on failure (when the token
 * contract returns false). Tokens that return no value (and instead revert or
 * throw on failure) are also supported, non-reverting calls are assumed to be
 * successful.
 * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract,
 * which allows you to call the safe operations as `token.safeTransfer(...)`, etc.
 */
library SafeERC20 {
    using SafeMath for uint256;
    using Address for address;

    function safeTransfer(IERC20 token, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
    }

    function safeTransferFrom(IERC20 token, address from, address to, uint256 value) internal {
        _callOptionalReturn(token, abi.encodeWithSelector(token.transferFrom.selector, from, to, value));
    }

    /**
     * @dev Deprecated. This function has issues similar to the ones found in
     * {IERC20-approve}, and its usage is discouraged.
     *
     * Whenever possible, use {safeIncreaseAllowance} and
     * {safeDecreaseAllowance} instead.
     */
    function safeApprove(IERC20 token, address spender, uint256 value) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        // solhint-disable-next-line max-line-length
        require((value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
    }

    function safeIncreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        uint256 newAllowance = token.allowance(address(this), spender).add(value);
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    function safeDecreaseAllowance(IERC20 token, address spender, uint256 value) internal {
        uint256 newAllowance = token.allowance(address(this), spender).sub(value, "SafeERC20: decreased allowance below zero");
        _callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, newAllowance));
    }

    /**
     * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement
     * on the return value: the return value is optional (but if data is returned, it must not be false).
     * @param token The token targeted by the call.
     * @param data The call data (encoded using abi.encode or one of its variants).
     */
    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since
        // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that
        // the target address contains contract code and also asserts for success in the low-level call.

        bytes memory returndata = address(token).functionCall(data, "SafeERC20: low-level call failed");
        if (returndata.length > 0) { // Return data is optional
            // solhint-disable-next-line max-line-length
            require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
        }
    }
}


// File contracts/libraries/FixedPointMath.sol

pragma solidity ^0.6.12;

library FixedPointMath {
  uint256 public constant DECIMALS = 18;
  uint256 public constant SCALAR = 10**DECIMALS;

  struct uq192x64 {
    uint256 x;
  }

  function fromU256(uint256 value) internal pure returns (uq192x64 memory) {
    uint256 x;
    require(value == 0 || (x = value * SCALAR) / SCALAR == value);
    return uq192x64(x);
  }

  function maximumValue() internal pure returns (uq192x64 memory) {
    return uq192x64(uint256(-1));
  }

  function add(uq192x64 memory self, uq192x64 memory value) internal pure returns (uq192x64 memory) {
    uint256 x;
    require((x = self.x + value.x) >= self.x);
    return uq192x64(x);
  }

  function add(uq192x64 memory self, uint256 value) internal pure returns (uq192x64 memory) {
    return add(self, fromU256(value));
  }

  function sub(uq192x64 memory self, uq192x64 memory value) internal pure returns (uq192x64 memory) {
    uint256 x;
    require((x = self.x - value.x) <= self.x);
    return uq192x64(x);
  }

  function sub(uq192x64 memory self, uint256 value) internal pure returns (uq192x64 memory) {
    return sub(self, fromU256(value));
  }

  function mul(uq192x64 memory self, uint256 value) internal pure returns (uq192x64 memory) {
    uint256 x;
    require(value == 0 || (x = self.x * value) / value == self.x);
    return uq192x64(x);
  }

  function div(uq192x64 memory self, uint256 value) internal pure returns (uq192x64 memory) {
    require(value != 0);
    return uq192x64(self.x / value);
  }

  function cmp(uq192x64 memory self, uq192x64 memory value) internal pure returns (int256) {
    if (self.x < value.x) {
      return -1;
    }

    if (self.x > value.x) {
      return 1;
    }

    return 0;
  }

  function decode(uq192x64 memory self) internal pure returns (uint256) {
    return self.x / SCALAR;
  }
}


// File contracts/interfaces/IDetailedERC20.sol

pragma solidity ^0.6.12;

interface IDetailedERC20 is IERC20 {
  function name() external returns (string memory);
  function symbol() external returns (string memory);
  function decimals() external returns (uint8);
}


// File hardhat/[email protected]

pragma solidity >= 0.4.22 <0.9.0;

library console {
	address constant CONSOLE_ADDRESS = address(0x000000000000000000636F6e736F6c652e6c6f67);

	function _sendLogPayload(bytes memory payload) private view {
		uint256 payloadLength = payload.length;
		address consoleAddress = CONSOLE_ADDRESS;
		assembly {
			let payloadStart := add(payload, 32)
			let r := staticcall(gas(), consoleAddress, payloadStart, payloadLength, 0, 0)
		}
	}

	function log() internal view {
		_sendLogPayload(abi.encodeWithSignature("log()"));
	}

	function logInt(int p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(int)", p0));
	}

	function logUint(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function logString(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function logBool(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function logAddress(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function logBytes(bytes memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes)", p0));
	}

	function logBytes1(bytes1 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes1)", p0));
	}

	function logBytes2(bytes2 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes2)", p0));
	}

	function logBytes3(bytes3 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes3)", p0));
	}

	function logBytes4(bytes4 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes4)", p0));
	}

	function logBytes5(bytes5 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes5)", p0));
	}

	function logBytes6(bytes6 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes6)", p0));
	}

	function logBytes7(bytes7 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes7)", p0));
	}

	function logBytes8(bytes8 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes8)", p0));
	}

	function logBytes9(bytes9 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes9)", p0));
	}

	function logBytes10(bytes10 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes10)", p0));
	}

	function logBytes11(bytes11 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes11)", p0));
	}

	function logBytes12(bytes12 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes12)", p0));
	}

	function logBytes13(bytes13 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes13)", p0));
	}

	function logBytes14(bytes14 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes14)", p0));
	}

	function logBytes15(bytes15 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes15)", p0));
	}

	function logBytes16(bytes16 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes16)", p0));
	}

	function logBytes17(bytes17 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes17)", p0));
	}

	function logBytes18(bytes18 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes18)", p0));
	}

	function logBytes19(bytes19 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes19)", p0));
	}

	function logBytes20(bytes20 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes20)", p0));
	}

	function logBytes21(bytes21 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes21)", p0));
	}

	function logBytes22(bytes22 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes22)", p0));
	}

	function logBytes23(bytes23 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes23)", p0));
	}

	function logBytes24(bytes24 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes24)", p0));
	}

	function logBytes25(bytes25 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes25)", p0));
	}

	function logBytes26(bytes26 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes26)", p0));
	}

	function logBytes27(bytes27 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes27)", p0));
	}

	function logBytes28(bytes28 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes28)", p0));
	}

	function logBytes29(bytes29 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes29)", p0));
	}

	function logBytes30(bytes30 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes30)", p0));
	}

	function logBytes31(bytes31 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes31)", p0));
	}

	function logBytes32(bytes32 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes32)", p0));
	}

	function log(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function log(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function log(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function log(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function log(uint p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint)", p0, p1));
	}

	function log(uint p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string)", p0, p1));
	}

	function log(uint p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool)", p0, p1));
	}

	function log(uint p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address)", p0, p1));
	}

	function log(string memory p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint)", p0, p1));
	}

	function log(string memory p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string)", p0, p1));
	}

	function log(string memory p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool)", p0, p1));
	}

	function log(string memory p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address)", p0, p1));
	}

	function log(bool p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint)", p0, p1));
	}

	function log(bool p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string)", p0, p1));
	}

	function log(bool p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool)", p0, p1));
	}

	function log(bool p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address)", p0, p1));
	}

	function log(address p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint)", p0, p1));
	}

	function log(address p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string)", p0, p1));
	}

	function log(address p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool)", p0, p1));
	}

	function log(address p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address)", p0, p1));
	}

	function log(uint p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint)", p0, p1, p2));
	}

	function log(uint p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string)", p0, p1, p2));
	}

	function log(uint p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool)", p0, p1, p2));
	}

	function log(uint p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address)", p0, p1, p2));
	}

	function log(uint p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint)", p0, p1, p2));
	}

	function log(uint p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string)", p0, p1, p2));
	}

	function log(uint p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool)", p0, p1, p2));
	}

	function log(uint p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address)", p0, p1, p2));
	}

	function log(uint p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint)", p0, p1, p2));
	}

	function log(uint p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string)", p0, p1, p2));
	}

	function log(uint p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool)", p0, p1, p2));
	}

	function log(uint p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address)", p0, p1, p2));
	}

	function log(string memory p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint)", p0, p1, p2));
	}

	function log(string memory p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string)", p0, p1, p2));
	}

	function log(string memory p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool)", p0, p1, p2));
	}

	function log(string memory p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address)", p0, p1, p2));
	}

	function log(bool p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint)", p0, p1, p2));
	}

	function log(bool p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string)", p0, p1, p2));
	}

	function log(bool p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool)", p0, p1, p2));
	}

	function log(bool p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address)", p0, p1, p2));
	}

	function log(bool p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint)", p0, p1, p2));
	}

	function log(bool p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string)", p0, p1, p2));
	}

	function log(bool p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool)", p0, p1, p2));
	}

	function log(bool p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address)", p0, p1, p2));
	}

	function log(bool p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint)", p0, p1, p2));
	}

	function log(bool p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string)", p0, p1, p2));
	}

	function log(bool p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool)", p0, p1, p2));
	}

	function log(bool p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address)", p0, p1, p2));
	}

	function log(address p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint)", p0, p1, p2));
	}

	function log(address p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string)", p0, p1, p2));
	}

	function log(address p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool)", p0, p1, p2));
	}

	function log(address p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address)", p0, p1, p2));
	}

	function log(address p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint)", p0, p1, p2));
	}

	function log(address p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string)", p0, p1, p2));
	}

	function log(address p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool)", p0, p1, p2));
	}

	function log(address p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address)", p0, p1, p2));
	}

	function log(address p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint)", p0, p1, p2));
	}

	function log(address p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string)", p0, p1, p2));
	}

	function log(address p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool)", p0, p1, p2));
	}

	function log(address p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address)", p0, p1, p2));
	}

	function log(address p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint)", p0, p1, p2));
	}

	function log(address p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string)", p0, p1, p2));
	}

	function log(address p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool)", p0, p1, p2));
	}

	function log(address p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address)", p0, p1, p2));
	}

	function log(uint p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, b...

// [truncated — 126994 bytes total]

Read Contract

MAXIMUM_COLLATERALIZATION_LIMIT 0x0510111e → uint256
MINIMUM_COLLATERALIZATION_LIMIT 0x30d4d190 → uint256
PERCENT_RESOLUTION 0x45f867b3 → uint256
ZERO_ADDRESS 0x538ba4f9 → address
_linkGasOracle 0xa005fda3 → address
collateralizationLimit 0x4aaf7c65 → tuple
emergencyExit 0x5641ec03 → bool
flushActivator 0xf0d787a3 → uint256
getCdpLastDeposit 0x9a9af221 → uint256
getCdpTotalCredit 0xfc00e8a0 → uint256
getCdpTotalDebt 0xaa6e0434 → uint256
getCdpTotalDeposited 0xa1e401a9 → uint256
getVaultAdapter 0x2670fdd8 → address
getVaultTotalDeposited 0xaaf16660 → uint256
governance 0x5aa6e675 → address
harvestFee 0xb5962917 → uint256
initialized 0x158ef93e → bool
pegMinimum 0x3847f038 → uint256
pendingGovernance 0xf39c38a0 → address
rewards 0x9ec5a894 → address
sentinel 0xf58c251c → address
token 0xfc0c546a → address
totalDeposited 0xff50abdc → uint256
transmuter 0x7239d2b9 → address
vaultCount 0xa7c6a100 → uint256
xtoken 0x1718a68f → address

Write Contract 21 functions

These functions modify contract state and require a wallet transaction to execute.

acceptGovernance 0x238efcbc
No parameters
deposit 0xb6b55f25
uint256 _amount
flush 0x6b9f96ea
No parameters
returns: uint256
harvest 0xddc63262
uint256 _vaultId
returns: uint256, uint256
initialize 0xc4d66de8
address _adapter
liquidate 0x415f1240
uint256 _amount
returns: uint256, uint256
migrate 0xce5494bb
address _adapter
mint 0xa0712d68
uint256 _amount
recall 0xfefdc5d1
uint256 _vaultId
uint256 _amount
returns: uint256, uint256
recallAll 0x4c3a8e02
uint256 _vaultId
returns: uint256, uint256
repay 0xd8aed145
uint256 _parentAmount
uint256 _childAmount
setCollateralizationLimit 0x53ffa18b
uint256 _limit
setEmergencyExit 0x45ee0755
bool _emergencyExit
setFlushActivator 0x22c37b75
uint256 _flushActivator
setHarvestFee 0x792b55b6
uint256 _harvestFee
setOracleAddress 0x5a9b5e92
address Oracle
uint256 peg
setPendingGovernance 0x0abb6035
address _pendingGovernance
setRewards 0xec38a862
address _rewards
setSentinel 0x09dac061
address _sentinel
setTransmuter 0xadb4a9ad
address _transmuter
withdraw 0x2e1a7d4d
uint256 _amount
returns: uint256, uint256

Recent Transactions

No transactions found for this address