Address Contract Partially Verified
Address
0xa4D1a2693589840BABb7f3A44D14Fdf41b3bF1Fe
Balance
0 ETH
Nonce
1
Code Size
21487 bytes
Creator
Create2 Deployer at tx 0x850148f4...1dec4c
Indexed Transactions
0 (1 on-chain, 1.6% indexed)
Contract Bytecode
21487 bytes
0x6080604052600436106102715763ffffffff7c01000000000000000000000000000000000000000000000000000000006000350416630803fac081146102765780631aa430781461029f5780631e526610146102c65780632914b9bd146102eb5780632d5735011461036d57806332f0a3b51461039b5780633c624c75146103b05780634b12311c146103c55780635a55c1f01461041a5780635eb243321461054157806362de7e5a146105635780637bbddcfc146105785780637c1d0b87146105a65780637e7db6e1146105c857806380afdea8146105f6578063868ce31a1461060b5780638b3dd749146106205780638b5683271461063557806393f89a801461064a5780639d4941d814610662578063a1658fad14610690578063a479e50814610704578063a87f862414610719578063b6f6825414610774578063b879572514610789578063bcf93dd61461079e578063be2c64d4146107d0578063c0774df3146107e5578063c54c24b514610859578063c5bb87581461086e578063c91d956c14610883578063cc63604a1461089b578063cdb2867b146108b3578063d4aae0c4146108e4578063d5db2c80146108f9578063d948d46814610925578063dc177eec1461097e578063dc474b1a14610993578063de4796ed146109a8578063de4f6347146109bd578063df133bca146109d2578063df136602146109f4578063df35219714610a09578063eb1e3b7714610a1e578063ee0f160e14610a33578063f4b0051314610a48578063f98a4eca14610a7e578063fad167ab14610a96578063fc0c546a14610aab578063fc157cb414610ac0578063fd64eccb14610ad5578063ff31183814610aea575b600080fd5b34801561028257600080fd5b5061028b610aff565b604080519115158252519081900360200190f35b3480156102ab57600080fd5b506102b4610b29565b60408051918252519081900360200190f35b3480156102d257600080fd5b506102e96004356024356044356064351515610b2f565b005b3480156102f757600080fd5b506040805160206004803580820135601f8101849004840285018401909552848452610344943694929360249392840191908190840183828082843750949750610d809650505050505050565b6040805173ffffffffffffffffffffffffffffffffffffffff9092168252519081900360200190f35b34801561037957600080fd5b5061028b73ffffffffffffffffffffffffffffffffffffffff60043516610e8c565b3480156103a757600080fd5b50610344610f90565b3480156103bc57600080fd5b506102b461102f565b3480156103d157600080fd5b506103f660043573ffffffffffffffffffffffffffffffffffffffff60243516611053565b6040518082600381111561040657fe5b60ff16815260200191505060405180910390f35b34801561042657600080fd5b50610432600435611139565b604051808b1515151581526020018a1515151581526020018967ffffffffffffffff1667ffffffffffffffff1681526020018867ffffffffffffffff1667ffffffffffffffff1681526020018767ffffffffffffffff1667ffffffffffffffff1681526020018667ffffffffffffffff1667ffffffffffffffff16815260200185815260200184815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b838110156104fd5781810151838201526020016104e5565b50505050905090810190601f16801561052a5780820380516001836020036101000a031916815260200191505b509b50505050505050505050505060405180910390f35b34801561054d57600080fd5b506102e967ffffffffffffffff6004351661134f565b34801561056f57600080fd5b506102b461156b565b34801561058457600080fd5b506102b473ffffffffffffffffffffffffffffffffffffffff6004351661158f565b3480156105b257600080fd5b506102e967ffffffffffffffff600435166115a1565b3480156105d457600080fd5b5061028b73ffffffffffffffffffffffffffffffffffffffff60043516611886565b34801561060257600080fd5b506102b461188c565b34801561061757600080fd5b506102b46118bc565b34801561062c57600080fd5b506102b46118e0565b34801561064157600080fd5b506102b461190b565b34801561065657600080fd5b506102e9600435611911565b34801561066e57600080fd5b506102e973ffffffffffffffffffffffffffffffffffffffff60043516611ad6565b34801561069c57600080fd5b50604080516020600460443581810135838102808601850190965280855261028b95833573ffffffffffffffffffffffffffffffffffffffff16956024803596369695606495939492019291829185019084908082843750949750611df89650505050505050565b34801561071057600080fd5b50610344611f88565b34801561072557600080fd5b506102e973ffffffffffffffffffffffffffffffffffffffff6004351667ffffffffffffffff6024358116906044358116906064351660843560a43560c43560e435610104356101243561204a565b34801561078057600080fd5b506102b461275f565b34801561079557600080fd5b506102b4612783565b3480156107aa57600080fd5b506107b3612789565b6040805167ffffffffffffffff9092168252519081900360200190f35b3480156107dc57600080fd5b506102b46127a5565b3480156107f157600080fd5b5060408051602060046024803582810135601f810185900485028601850190965285855261028b95833573ffffffffffffffffffffffffffffffffffffffff169536956044949193909101919081908401838280828437509497506127c99650505050505050565b34801561086557600080fd5b506102b4612814565b34801561087a57600080fd5b506102b4612838565b34801561088f57600080fd5b506102e960043561283e565b3480156108a757600080fd5b5061028b600435612a01565b3480156108bf57600080fd5b5061028b60043573ffffffffffffffffffffffffffffffffffffffff60243516612ab9565b3480156108f057600080fd5b50610344612b71565b34801561090557600080fd5b506102b46024600480358281019290820135918135918201910135612b9c565b34801561093157600080fd5b506040805160206004803580820135601f81018490048402850184019095528484526102e9943694929360249392840191908190840183828082843750949750612cf09650505050505050565b34801561098a57600080fd5b506102e9612db9565b34801561099f57600080fd5b506107b3612ec2565b3480156109b457600080fd5b5061028b612ed2565b3480156109c957600080fd5b506102b4612f03565b3480156109de57600080fd5b506102e960043560243515156044351515612f09565b348015610a0057600080fd5b506102e96131cd565b348015610a1557600080fd5b506102b46132d9565b348015610a2a57600080fd5b506102b46132df565b348015610a3f57600080fd5b5061028b6132e5565b348015610a5457600080fd5b506102b46024600480358281019290820135918135918201910135604435151560643515156132ee565b348015610a8a57600080fd5b506102e9600435613443565b348015610aa257600080fd5b506107b36134ee565b348015610ab757600080fd5b50610344613516565b348015610acc57600080fd5b506107b3613532565b348015610ae157600080fd5b5061028b61353e565b348015610af657600080fd5b506102b4613543565b600080610b0a6118e0565b90508015801590610b22575080610b1f613567565b10155b91505b5090565b60075481565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f5445000000000000000000000000000000000000602082015285918210610c0c576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825283818151815260200191508051906020019080838360005b83811015610bd1578181015183820152602001610bb9565b50505050905090810190601f168015610bfe5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50610c17853361356b565b60408051808201909152601381527f564f54494e475f43414e5f4e4f545f564f5445000000000000000000000000006020820152901515610cb4576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50670de0b6b3a7640000610cce858563ffffffff61365216565b60408051808201909152601981527f4d414c464f524d45445f434f4e54494e554f55535f564f5445000000000000006020820152911015610d6b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50610d7985858533866136f7565b5050505050565b6000610d8a611f88565b73ffffffffffffffffffffffffffffffffffffffff166304bf2a7f836040518263ffffffff167c01000000000000000000000000000000000000000000000000000000000281526004018080602001828103825283818151815260200191508051906020019080838360005b83811015610e0e578181015183820152602001610df6565b50505050905090810190601f168015610e3b5780820380516001836020036101000a031916815260200191505b5092505050602060405180830381600087803b158015610e5a57600080fd5b505af1158015610e6e573d6000803e3d6000fd5b505050506040513d6020811015610e8457600080fd5b505192915050565b60085460009060ff168015610f46575060065460008054604080517f70a0823100000000000000000000000000000000000000000000000000000000815273ffffffffffffffffffffffffffffffffffffffff8781166004830152915191909216926370a0823192602480820193602093909283900390910190829087803b158015610f1757600080fd5b505af1158015610f2b573d6000803e3d6000fd5b505050506040513d6020811015610f4157600080fd5b505110155b8015610f8a575073ffffffffffffffffffffffffffffffffffffffff82166000908152600b6020526040902054600754610f8790429063ffffffff613b1916565b10155b92915050565b6000610f9a612b71565b73ffffffffffffffffffffffffffffffffffffffff166332f0a3b56040518163ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401602060405180830381600087803b158015610ffd57600080fd5b505af1158015611011573d6000803e3d6000fd5b505050506040513d602081101561102757600080fd5b505190505b90565b7fad15e7261800b4bb73f1b69d3864565ffb1fd00cb93cf14fe48da8f1f2149f3981565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f5445000000000000000000000000000000000000602082015260009184919082106110f8576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50600084815260096020908152604080832073ffffffffffffffffffffffffffffffffffffffff8716845260060190915290205460ff1691505b5092915050565b6000806000806000806000806000606060008b600a5481106040805190810160405280600e81526020017f564f54494e475f4e4f5f564f54450000000000000000000000000000000000008152509015156111f0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5060008d8152600960205260409020915061120a82613bc4565b9b508160000160009054906101000a900460ff169a508160000160019054906101000a900467ffffffffffffffff1699508160000160099054906101000a900467ffffffffffffffff1698508160000160119054906101000a900467ffffffffffffffff1697508160010160009054906101000a900467ffffffffffffffff169650816002015495508160030154945081600401549350816005018054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156113395780601f1061130e57610100808354040283529160200191611339565b820191906000526020600020905b81548152906001019060200180831161131c57829003601f168201915b5050505050925050509193959799509193959799565b6001547fad15e7261800b4bb73f1b69d3864565ffb1fd00cb93cf14fe48da8f1f2149f399061138b9067ffffffffffffffff8085169116613c27565b611396338383611df8565b60408051808201909152600f81527f4150505f415554485f4641494c454400000000000000000000000000000000006020820152901515611433576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5060005460408051808201909152601981527f564f54494e475f4348414e47455f51554f52554d5f504354530000000000000060208201529067ffffffffffffffff74010000000000000000000000000000000000000000909104811690851611156114fb576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b506001805467ffffffffffffffff85167fffffffffffffffffffffffffffffffffffffffffffffffff0000000000000000909116811790915560408051918252517f3172f2e9273c729c2a47cc8bf7e7f18506e3e3035126d562602bd2155bc78a509181900360200190a1505050565b7fda3972983e62bdf826c4b807c4c9c2b8a941e1f83dfa76d53d6aeac11e1be65081565b600b6020526000908152604090205481565b6000547fda3972983e62bdf826c4b807c4c9c2b8a941e1f83dfa76d53d6aeac11e1be650906115f59067ffffffffffffffff8085169174010000000000000000000000000000000000000000900416613c27565b611600338383611df8565b60408051808201909152600f81527f4150505f415554485f4641494c45440000000000000000000000000000000000602082015290151561169d576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5060015460408051808201909152601a81527f564f54494e475f4348414e47455f535550504f52545f5043545300000000000060208201529067ffffffffffffffff8086169116111561174c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5060408051808201909152601a81527f564f54494e475f4348414e47455f535550505f544f4f5f4249470000000000006020820152670de0b6b3a764000067ffffffffffffffff8516106117fc576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b506000805467ffffffffffffffff85167401000000000000000000000000000000000000000081027fffffffff0000000000000000ffffffffffffffffffffffffffffffffffffffff9092169190911790915560408051918252517f903b617f7f36eb047a29b89d1bf7885fdae31d250c3320fccf11d045c11b396e9181900360200190a1505050565b50600190565b60006118b77fd625496217aa6a3453eecb9c3489dc5a53e6c67b444329ea2b2cbc9ff547639b613c82565b905090565b7fecb50dc3e77ba8a59697a3cc090a29b4cbd3c1f2b6b3aea524e0d166969592b981565b60006118b77febb05b386a8d34882b8711d156f463690983dc47815980fb82aeeff1aa43579e613c82565b60035481565b604080516000808252602082019092527fe7ab0252519cd959720b328191bed7fe61b8e25f77613877be7070646d12daf0916119539133918491905b50611df8565b60408051808201909152600f81527f4150505f415554485f4641494c4544000000000000000000000000000000000060208201529015156119f0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50816004548110158015611a0657506005548111155b1515611a9957604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152603960248201527f4d696e2074696d652073686f756c642062652077697468696e20696e6974696160448201527f6c697a6174696f6e2068617264636f646564206c696d69747300000000000000606482015290519081900360840190fd5b60078390556040805184815290517fcb34d0577abe5b2f96b65ea1bb5de2209ba6309c6909438c6d50dd277ca3b5809181900360200190a1505050565b6000806000611ae484611886565b60408051808201909152601281527f5245434f5645525f444953414c4c4f57454400000000000000000000000000006020820152901515611b81576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50611b8a610f90565b9250611b9583613c8a565b60408051808201909152601a81527f5245434f5645525f5641554c545f4e4f545f434f4e54524143540000000000006020820152901515611c32576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5073ffffffffffffffffffffffffffffffffffffffff84161515611c9d576040513031925073ffffffffffffffffffffffffffffffffffffffff84169083156108fc029084906000818181858888f19350505050158015611c97573d6000803e3d6000fd5b50611d8d565b5082611cc573ffffffffffffffffffffffffffffffffffffffff82163063ffffffff613cbd16565b9150611cee73ffffffffffffffffffffffffffffffffffffffff8216848463ffffffff613df616565b60408051808201909152601d81527f5245434f5645525f544f4b454e5f5452414e534645525f4641494c45440000006020820152901515611d8b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b505b8373ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f596caf56044b55fb8c4ca640089bbc2b63cae3e978b851f5745cbb7c5b288e02846040518082815260200191505060405180910390a350505050565b600080611e03610aff565b1515611e125760009150611f80565b611e1a612b71565b905073ffffffffffffffffffffffffffffffffffffffff81161515611e425760009150611f80565b8073ffffffffffffffffffffffffffffffffffffffff1663fdef9106863087611e6a88613e8e565b6040517c010000000000000000000000000000000000000000000000000000000063ffffffff871602815273ffffffffffffffffffffffffffffffffffffffff808616600483019081529085166024830152604482018490526080606483019081528351608484015283519192909160a490910190602085019080838360005b83811015611f02578181015183820152602001611eea565b50505050905090810190601f168015611f2f5780820380516001836020036101000a031916815260200191505b5095505050505050602060405180830381600087803b158015611f5157600080fd5b505af1158015611f65573d6000803e3d6000fd5b505050506040513d6020811015611f7b57600080fd5b505191505b509392505050565b600080611f93612b71565b604080517fbe00bbd80000000000000000000000000000000000000000000000000000000081527fd6f028ca0e8edb4a8c9757ca4fdccab25fa1e0317da1188108f7d2dee14902fb60048201527fddbcfd564f642ab5627cf68b9b7d374fb4f8a36e941a75d89c87998cef03bd616024820152905173ffffffffffffffffffffffffffffffffffffffff929092169163be00bbd8916044808201926020929091908290030181600087803b158015610e5a57600080fd5b60006120546118e0565b60408051808201909152601881527f494e49545f414c52454144595f494e495449414c495a45440000000000000000602082015290156120f0576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50604080517f4352454154455f564f5445535f524f4c45000000000000000000000000000000815290519081900360110190207fe7dcd7275292e064d090fbc5f3bd7995be23b502c1fed5cd94cfddbbdcd32bbc1461214b57fe5b604080517f4d4f444946595f535550504f52545f524f4c4500000000000000000000000000815290519081900360130190207fda3972983e62bdf826c4b807c4c9c2b8a941e1f83dfa76d53d6aeac11e1be650146121a557fe5b604080517f4d4f444946595f51554f52554d5f524f4c450000000000000000000000000000815290519081900360120190207fad15e7261800b4bb73f1b69d3864565ffb1fd00cb93cf14fe48da8f1f2149f39146121ff57fe5b604080517f5345545f4d494e5f42414c414e43455f524f4c45000000000000000000000000815290519081900360140190207fb1f3f26f63ad27cd630737a426f990492f5c674208299d6fb23bb2b0733d3d661461225957fe5b604080517f5345545f4d494e5f54494d455f524f4c45000000000000000000000000000000815290519081900360110190207fe7ab0252519cd959720b328191bed7fe61b8e25f77613877be7070646d12daf0146122b357fe5b604080517f44495341424c455f564f54455f4352454154494f4e0000000000000000000000815290519081900360150190207f40b01f8b31b51596de2eeab8c325ff77cc3695c1c1875d66ff31176e7148d2a11461230d57fe5b604080517f454e41424c455f564f54455f4352454154494f4e000000000000000000000000815290519081900360140190207fecb50dc3e77ba8a59697a3cc090a29b4cbd3c1f2b6b3aea524e0d166969592b91461236757fe5b61236f613e98565b60408051808201909152601081527f564f54494e475f494e49545f5043545300000000000000000000000000000000602082015267ffffffffffffffff808c16908b16111561241a576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5060408051808201909152601b81527f564f54494e475f494e49545f535550504f52545f544f4f5f42494700000000006020820152670de0b6b3a764000067ffffffffffffffff8c16106124ca576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b508487101580156124db5750838711155b15156124e657600080fd5b8286101580156124f65750818611155b151561250157600080fd5b8a6000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555089600060146101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555088600160006101000a81548167ffffffffffffffff021916908367ffffffffffffffff16021790555087600160086101000a81548167ffffffffffffffff021916908367ffffffffffffffff1602179055506000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663313ce5676040518163ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401602060405180830381600087803b15801561264157600080fd5b505af1158015612655573d6000803e3d6000fd5b505050506040513d602081101561266b57600080fd5b505160ff16600a0a9050612685878263ffffffff613f7716565b600655600786905561269d858263ffffffff613f7716565b6002556126b0848263ffffffff613f7716565b6003556004839055600582905560065460408051918252517fbd5318adc778260bd213cc16f3ef06cfb4f729adb9309495fed0e10abc61c3759181900360200190a160075460408051918252517fcb34d0577abe5b2f96b65ea1bb5de2209ba6309c6909438c6d50dd277ca3b5809181900360200190a15050600880547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00166001179055505050505050505050565b7fb1f3f26f63ad27cd630737a426f990492f5c674208299d6fb23bb2b0733d3d6681565b60045481565b60015468010000000000000000900467ffffffffffffffff1681565b7fe7dcd7275292e064d090fbc5f3bd7995be23b502c1fed5cd94cfddbbdcd32bbc81565b60006127fd837fe7dcd7275292e064d090fbc5f3bd7995be23b502c1fed5cd94cfddbbdcd32bbc6127f8614039565b611df8565b801561280d575061280d83610e8c565b9392505050565b7fe7ab0252519cd959720b328191bed7fe61b8e25f77613877be7070646d12daf081565b60065481565b604080516000808252602082019092527fb1f3f26f63ad27cd630737a426f990492f5c674208299d6fb23bb2b0733d3d669161287e91339184919061194d565b60408051808201909152600f81527f4150505f415554485f4641494c45440000000000000000000000000000000000602082015290151561291b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5081600254811015801561293157506003548111155b15156129c457604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152603c60248201527f4d696e2062616c616e63652073686f756c642062652077697468696e20696e6960448201527f7469616c697a6174696f6e2068617264636f646564206c696d69747300000000606482015290519081900360840190fd5b60068390556040805184815290517fbd5318adc778260bd213cc16f3ef06cfb4f729adb9309495fed0e10abc61c3759181900360200190a1505050565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f544500000000000000000000000000000000000060208201526000918391908210612aa6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612ab08361404b565b91505b50919050565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f544500000000000000000000000000000000000060208201526000918491908210612b5e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612b69848461356b565b949350505050565b60006118b77f4172f0f7d2289153072b0a6ca36959e0cbe2efc3afe50fc81636caa96338137b613c82565b604080516000808252602082019092527fe7dcd7275292e064d090fbc5f3bd7995be23b502c1fed5cd94cfddbbdcd32bbc90612bdc90339083908561194d565b60408051808201909152600f81527f4150505f415554485f4641494c454400000000000000000000000000000000006020820152901515612c79576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612ce686868080601f0160208091040260200160405190810160405280939291908181526020018383808284375050604080516020601f8c018190048102820181019092528a815294508a9350899250829150840183828082843782019150505050505060018061417a565b9695505050505050565b612cfa33826127c9565b60408051808201909152601681527f564f54494e475f43414e5f4e4f545f464f5257415244000000000000000000006020820152901515612d97576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612db581602060405190810160405280600081525060018061417a565b5050565b604080516000808252602082019092527f40b01f8b31b51596de2eeab8c325ff77cc3695c1c1875d66ff31176e7148d2a191612df991339184919061194d565b60408051808201909152600f81527f4150505f415554485f4641494c454400000000000000000000000000000000006020820152901515612e96576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5050600880547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00169055565b60015467ffffffffffffffff1681565b60007fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff612efd6118e0565b14905090565b600a5481565b60008080612f2886826fffffffffffffffffffffffffffffffff6146bb565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f54450000000000000000000000000000000000006020820152908210612fc8576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612fe58760006fffffffffffffffffffffffffffffffff6146bb565b9350612ffb87608067ffffffffffffffff6146bb565b92506130118760c067ffffffffffffffff6146bb565b915061301d843361356b565b60408051808201909152601381527f564f54494e475f43414e5f4e4f545f564f54450000000000000000000000000060208201529015156130ba576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50811580156130c7575082155b156130f35785156130e257670de0b6b3a764000091506130ee565b670de0b6b3a764000092505b6131b7565b851580156131185750670de0b6b3a7640000613115838563ffffffff61365216565b11155b60408051808201909152601981527f4d414c464f524d45445f434f4e54494e554f55535f564f54450000000000000060208201529015156131b5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b505b6131c484838533896136f7565b50505050505050565b604080516000808252602082019092527fecb50dc3e77ba8a59697a3cc090a29b4cbd3c1f2b6b3aea524e0d166969592b99161320d91339184919061194d565b60408051808201909152600f81527f4150505f415554485f4641494c4544000000000000000000000000000000000060208201529015156132aa576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5050600880547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00166001179055565b60055481565b60025481565b60085460ff1681565b604080516000808252602082019092527fe7dcd7275292e064d090fbc5f3bd7995be23b502c1fed5cd94cfddbbdcd32bbc9061332e90339083908561194d565b60408051808201909152600f81527f4150505f415554485f4641494c4544000000000000000000000000000000000060208201529015156133cb576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5061343788888080601f0160208091040260200160405190810160405280939291908181526020018383808284375050604080516020601f8e018190048102820181019092528c815294508c93508b92508291508401838280828437820191505050505050868661417a565b98975050505050505050565b600a5460408051808201909152600e81527f564f54494e475f4e4f5f564f54450000000000000000000000000000000000006020820152829182106134e4576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50612db5826146c8565b60005474010000000000000000000000000000000000000000900467ffffffffffffffff1681565b60005473ffffffffffffffffffffffffffffffffffffffff1681565b670de0b6b3a764000081565b600190565b7f40b01f8b31b51596de2eeab8c325ff77cc3695c1c1875d66ff31176e7148d2a181565b4390565b600082815260096020526040812061358281613bc4565b8015612b695750600080548254604080517f4ee2cd7e00000000000000000000000000000000000000000000000000000000815273ffffffffffffffffffffffffffffffffffffffff8881166004830152690100000000000000000090930467ffffffffffffffff16602482015290519190921691634ee2cd7e91604480830192602092919082900301818787803b15801561361d57600080fd5b505af1158015613631573d6000803e3d6000fd5b505050506040513d602081101561364757600080fd5b505111949350505050565b60408051808201909152601181527f4d4154485f4144445f4f564552464c4f5700000000000000000000000000000060208201526000908383019084821015611f80576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b600085815260096020908152604080832073ffffffffffffffffffffffffffffffffffffffff8616845260068101909252822054909160ff909116908080808085600381111561374357fe5b146137af57604080517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152601260248201527f43616e2774206368616e676520766f7465730000000000000000000000000000604482015290519081900360640190fd5b600080548754604080517f4ee2cd7e00000000000000000000000000000000000000000000000000000000815273ffffffffffffffffffffffffffffffffffffffff8d81166004830152690100000000000000000090930467ffffffffffffffff16602482015290519190921692634ee2cd7e92604480820193602093909283900390910190829087803b15801561384657600080fd5b505af115801561385a573d6000803e3d6000fd5b505050506040513d602081101561387057600080fd5b505160015490945061391d9068010000000000000000900467ffffffffffffffff166139116138ea6138a061477b565b6001548b546138d49161010090910467ffffffffffffffff908116916801000000000000000090041663ffffffff61478d16565b67ffffffffffffffff169063ffffffff61483f16565b67ffffffffffffffff1661390560028963ffffffff613f7716565b9063ffffffff613f7716565b9063ffffffff6148ef16565b92508383111561392b578392505b613947670de0b6b3a7640000613911858d63ffffffff613f7716565b9150613965670de0b6b3a7640000613911858c63ffffffff613f7716565b9050600082111561398b576002860154613985908363ffffffff61365216565b60028701555b60008111156139af5760038601546139a9908263ffffffff61365216565b60038701555b8082146139cc578082116139c45760026139c7565b60015b6139cf565b60035b73ffffffffffffffffffffffffffffffffffffffff89166000908152600688016020526040902080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00166001836003811115613a2857fe5b02179055506000821115613a8d57604080516001815260208101849052815173ffffffffffffffffffffffffffffffffffffffff8b16928e927fb34ee265e3d4f5ec4e8b52d59b2a9be8fceca2f274ebc080d8fba797fea9391f929081900390910190a35b6000811115613aed57604080516000815260208101839052815173ffffffffffffffffffffffffffffffffffffffff8b16928e927fb34ee265e3d4f5ec4e8b52d59b2a9be8fceca2f274ebc080d8fba797fea9391f929081900390910190a35b868015613afe5750613afe8b61404b565b15613b0c57613b0c8b6149a6565b5050505050505050505050565b60408051808201909152601281527f4d4154485f5355425f554e444552464c4f5700000000000000000000000000006020820152600090819084841115613bbc576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b505050900390565b6001548154600091613bfa91610100900467ffffffffffffffff908116916801000000000000000090041663ffffffff61478d16565b67ffffffffffffffff16613c0c61477b565b67ffffffffffffffff16108015610f8a5750505460ff161590565b604080516002808252606080830184529260208301908038833901905050905082816000815181101515613c5757fe5b602090810290910101528051829082906001908110613c7257fe5b6020908102909101015292915050565b5490565b5490565b60008073ffffffffffffffffffffffffffffffffffffffff83161515613cb35760009150612ab3565b50506000903b1190565b6040805173ffffffffffffffffffffffffffffffffffffffff83166024808301919091528251808303909101815260449091019091526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167f70a08231000000000000000000000000000000000000000000000000000000001790526000908180613d4a8684614ad9565b60408051808201909152601c81527f534146455f4552435f32305f42414c414e43455f52455645525445440000000060208201529193509150821515613dec576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5095945050505050565b6040805173ffffffffffffffffffffffffffffffffffffffff8416602482015260448082018490528251808303909101815260649091019091526020810180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff167fa9059cbb00000000000000000000000000000000000000000000000000000000179052600090613e858582614b0a565b95945050505050565b8051602002815290565b613ea06118e0565b60408051808201909152601881527f494e49545f414c52454144595f494e495449414c495a4544000000000000000060208201529015613f3c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50613f75613f48613567565b7febb05b386a8d34882b8711d156f463690983dc47815980fb82aeeff1aa43579e9063ffffffff614b5816565b565b600080831515613f8a5760009150611132565b50828202828482811515613f9a57fe5b60408051808201909152601181527f4d4154485f4d554c5f4f564552464c4f5700000000000000000000000000000060208201529291900414611f80576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b60408051600081526020810190915290565b60008181526009602052604081208161406382613bc4565b156140715760009250614173565b815460ff16156140845760009250614173565b6002820154600483015483546140ba92919071010000000000000000000000000000000000900467ffffffffffffffff16614b5c565b156140c85760019250614173565b6140d182613bc4565b156140df5760009250614173565b600382015460028301546140f89163ffffffff61365216565b6002830154835491925061412c91839071010000000000000000000000000000000000900467ffffffffffffffff16614b5c565b151561413b5760009250614173565b60028201546004830154600184015461415f92919067ffffffffffffffff16614b5c565b151561416e5760009250614173565b600192505b5050919050565b60008060008061418933610e8c565b151561419457600080fd5b600161419e614b9e565b60008054604080517f981b24d00000000000000000000000000000000000000000000000000000000081529490930367ffffffffffffffff81166004860152925192965073ffffffffffffffffffffffffffffffffffffffff169263981b24d09260248083019360209383900390910190829087803b15801561422057600080fd5b505af1158015614234573d6000803e3d6000fd5b505050506040513d602081101561424a57600080fd5b505160408051808201909152601681527f564f54494e475f4e4f5f564f54494e475f504f574552000000000000000000006020820152909250600083116142ed576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5050600a805460018101909155600081815260096020526040902090935061431361477b565b81547fffffffffffffffffffffffffffffffffffffffffffffff0000000000000000ff1661010067ffffffffffffffff92831602177fffffffffffffffffffffffffffffff0000000000000000ffffffffffffffffff16690100000000000000000085831602178083556000547fffffffffffffff0000000000000000ffffffffffffffffffffffffffffffffff9091167401000000000000000000000000000000000000000090910482167101000000000000000000000000000000000002178255600180549083018054919092167fffffffffffffffffffffffffffffffffffffffffffffffff000000000000000090911617905560048101829055875161442690600583019060208b0190615335565b503373ffffffffffffffffffffffffffffffffffffffff16847f0730610a5322c6584fb6f5bb760719e650c888cfd965a2beb2d598bcd425e394896006546007546000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166318160ddd6040518163ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401602060405180830381600087803b1580156144ec57600080fd5b505af1158015614500573d6000803e3d6000fd5b505050506040513d602081101561451657600080fd5b505160008054604080517f4ee2cd7e00000000000000000000000000000000000000000000000000000000815233600482015267ffffffffffffffff8e166024820152905173ffffffffffffffffffffffffffffffffffffffff90921692634ee2cd7e926044808401936020939083900390910190829087803b15801561459c57600080fd5b505af11580156145b0573d6000803e3d6000fd5b505050506040513d60208110156145c657600080fd5b5051604080516020818101879052918101859052606081018490526080810183905260a080825287519082015286519091829160c083019189019080838360005b8381101561461f578181015183820152602001614607565b50505050905090810190601f16801561464c5780820380516001836020036101000a031916815260200191505b50965050505050505060405180910390a361466561477b565b336000908152600b6020526040902067ffffffffffffffff9190911690558580156146955750614695843361356b565b156146b0576146b084670de0b6b3a7640000600033896136f7565b505050949350505050565b60029190910a9091041690565b6146d18161404b565b60408051808201909152601681527f564f54494e475f43414e5f4e4f545f4558454355544500000000000000000000602082015290151561476e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50614778816149a6565b50565b60006118b7614788614bab565b614baf565b60408051808201909152601381527f4d41544836345f4144445f4f564552464c4f570000000000000000000000000060208201526000908383019067ffffffffffffffff8086169083161015611f80576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b60408051808201909152601481527f4d41544836345f5355425f554e444552464c4f570000000000000000000000006020820152600090819067ffffffffffffffff8086169085161115613bbc576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b60408051808201909152600d81527f4d4154485f4449565f5a45524f0000000000000000000000000000000000000060208201526000908190818411614991576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50828481151561499d57fe5b04949350505050565b600081815260096020908152604080832080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0016600190811782558251948552600582018054600292811615610100027fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff011691909104601f81018590048502860184018452938501848152919493614aa893850182828015614a8b5780601f10614a6057610100808354040283529160200191614a8b565b820191906000526020600020905b815481529060010190602001808311614a6e57829003601f168201915b50506040805160008152602081019091528693509150614c5f9050565b5060405183907fbf8e2b108bb7c980e08903a8a46527699d5e84905a082d56dacb4150725c8cab90600090a2505050565b6000806000806040516020818751602089018a5afa92506000831115614afe57805191505b50909590945092505050565b6000806040516020818551602087016000895af16000811115614b4e573d8015614b3b5760208114614b4457614b4c565b60019350614b4c565b600183511493505b505b5090949350505050565b9055565b600080831515614b6f5760009150611f80565b83614b8886670de0b6b3a764000063ffffffff613f7716565b811515614b9157fe5b0492909211949350505050565b60006118b7614788613567565b4290565b60408051808201909152601581527f55494e5436345f4e554d4245525f544f4f5f4249470000000000000000000000602082015260009067ffffffffffffffff831115614c58576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b5090919050565b6060600080606080614c6f610aff565b60408051808201909152601481527f494e49545f4e4f545f494e495449414c495a45440000000000000000000000006020820152901515614d0c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b50600080614d18612b71565b9150614d2261188c565b9050614d2d8a610d80565b60408051808201909152601b81527f45564d52554e5f4558454355544f525f554e415641494c41424c450000000000602082015290965073ffffffffffffffffffffffffffffffffffffffff87161515614de3576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b506040516060602482019081528b5160848301528b517f279cea3500000000000000000000000000000000000000000000000000000000975087928d928d928d9282916044820191606481019160a490910190602089019080838360005b83811015614e59578181015183820152602001614e41565b50505050905090810190601f168015614e865780820380516001836020036101000a031916815260200191505b50848103835286518152865160209182019188019080838360005b83811015614eb9578181015183820152602001614ea1565b50505050905090810190601f168015614ee65780820380516001836020036101000a031916815260200191505b508481038252855181528551602091820191808801910280838360005b83811015614f1b578181015183820152602001614f03565b505050509050019650505050505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff83818316178352505050509350600080855160208701895af4604051935080801561502057603f3d118015614fbe5760203d03806020883e860160405261501a565b7f08c379a000000000000000000000000000000000000000000000000000000000865260206004870152601e60248701527f45564d52554e5f4558454355544f525f494e56414c49445f52455455524e00006044870152606486fd5b50615029565b3d6000863e3d85fd5b50508573ffffffffffffffffffffffffffffffffffffffff167f5229a5dba83a54ae8cb5b51bdd6de9474cacbe9dd332f5185f3a4f4f2e3f4ad98b8b8660405180806020018060200180602001848103845287818151815260200191508051906020019080838360005b838110156150ab578181015183820152602001615093565b50505050905090810190601f1680156150d85780820380516001836020036101000a031916815260200191505b50848103835286518152865160209182019188019080838360005b8381101561510b5781810151838201526020016150f3565b50505050905090810190601f1680156151385780820380516001836020036101000a031916815260200191505b50848103825285518152855160209182019187019080838360005b8381101561516b578181015183820152602001615153565b50505050905090810190601f1680156151985780820380516001836020036101000a031916815260200191505b50965050505050505060405180910390a28296508173ffffffffffffffffffffffffffffffffffffffff166151cb612b71565b73ffffffffffffffffffffffffffffffffffffffff16146040805190810160405280601f81526020017f45564d52554e5f50524f5445435445445f53544154455f4d4f44494649454400815250901515615281576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b508061528b61188c565b60408051808201909152601f81527f45564d52554e5f50524f5445435445445f53544154455f4d4f4449464945440060208201529114615327576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252838181518152602001915080519060200190808383600083811015610bd1578181015183820152602001610bb9565b505050505050509392505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061537657805160ff19168380011785556153a3565b828001600101855582156153a3579182015b828111156153a3578251825591602001919060010190615388565b50610b259261102c9250905b80821115610b2557600081556001016153af5600a165627a7a72305820a65003a6c94965a7db45161c90b46146f2a025baf582adae16ed92d3028eccf90029
Verified Source Code Partial Match
Compiler: v0.4.24+commit.e67f0147
EVM: byzantium
Optimization: Yes (10000 runs)
Voting.sol 2421 lines
// Sources flattened with hardhat v2.6.8 https://hardhat.org // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; library UnstructuredStorage { function getStorageBool(bytes32 position) internal view returns (bool data) { assembly { data := sload(position) } } function getStorageAddress(bytes32 position) internal view returns (address data) { assembly { data := sload(position) } } function getStorageBytes32(bytes32 position) internal view returns (bytes32 data) { assembly { data := sload(position) } } function getStorageUint256(bytes32 position) internal view returns (uint256 data) { assembly { data := sload(position) } } function setStorageBool(bytes32 position, bool data) internal { assembly { sstore(position, data) } } function setStorageAddress(bytes32 position, address data) internal { assembly { sstore(position, data) } } function setStorageBytes32(bytes32 position, bytes32 data) internal { assembly { sstore(position, data) } } function setStorageUint256(bytes32 position, uint256 data) internal { assembly { sstore(position, data) } } } // File @aragon/os/contracts/acl/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; interface IACL { function initialize(address permissionsCreator) external; // TODO: this should be external // See https://github.com/ethereum/solidity/issues/4832 function hasPermission(address who, address where, bytes32 what, bytes how) public view returns (bool); } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; interface IVaultRecoverable { event RecoverToVault(address indexed vault, address indexed token, uint256 amount); function transferToVault(address token) external; function allowRecoverability(address token) external view returns (bool); function getRecoveryVault() external view returns (address); } // File @aragon/os/contracts/kernel/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; interface IKernelEvents { event SetApp(bytes32 indexed namespace, bytes32 indexed appId, address app); } // This should be an interface, but interfaces can't inherit yet :( contract IKernel is IKernelEvents, IVaultRecoverable { function acl() public view returns (IACL); function hasPermission(address who, address where, bytes32 what, bytes how) public view returns (bool); function setApp(bytes32 namespace, bytes32 appId, address app) public; function getApp(bytes32 namespace, bytes32 appId) public view returns (address); } // File @aragon/os/contracts/apps/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract AppStorage { using UnstructuredStorage for bytes32; /* Hardcoded constants to save gas bytes32 internal constant KERNEL_POSITION = keccak256("aragonOS.appStorage.kernel"); bytes32 internal constant APP_ID_POSITION = keccak256("aragonOS.appStorage.appId"); */ bytes32 internal constant KERNEL_POSITION = 0x4172f0f7d2289153072b0a6ca36959e0cbe2efc3afe50fc81636caa96338137b; bytes32 internal constant APP_ID_POSITION = 0xd625496217aa6a3453eecb9c3489dc5a53e6c67b444329ea2b2cbc9ff547639b; function kernel() public view returns (IKernel) { return IKernel(KERNEL_POSITION.getStorageAddress()); } function appId() public view returns (bytes32) { return APP_ID_POSITION.getStorageBytes32(); } function setKernel(IKernel _kernel) internal { KERNEL_POSITION.setStorageAddress(address(_kernel)); } function setAppId(bytes32 _appId) internal { APP_ID_POSITION.setStorageBytes32(_appId); } } // File @aragon/os/contracts/acl/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract ACLSyntaxSugar { function arr() internal pure returns (uint256[]) { return new uint256[](0); } function arr(bytes32 _a) internal pure returns (uint256[] r) { return arr(uint256(_a)); } function arr(bytes32 _a, bytes32 _b) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b)); } function arr(address _a) internal pure returns (uint256[] r) { return arr(uint256(_a)); } function arr(address _a, address _b) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b)); } function arr(address _a, uint256 _b, uint256 _c) internal pure returns (uint256[] r) { return arr(uint256(_a), _b, _c); } function arr(address _a, uint256 _b, uint256 _c, uint256 _d) internal pure returns (uint256[] r) { return arr(uint256(_a), _b, _c, _d); } function arr(address _a, uint256 _b) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b)); } function arr(address _a, address _b, uint256 _c, uint256 _d, uint256 _e) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b), _c, _d, _e); } function arr(address _a, address _b, address _c) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b), uint256(_c)); } function arr(address _a, address _b, uint256 _c) internal pure returns (uint256[] r) { return arr(uint256(_a), uint256(_b), uint256(_c)); } function arr(uint256 _a) internal pure returns (uint256[] r) { r = new uint256[](1); r[0] = _a; } function arr(uint256 _a, uint256 _b) internal pure returns (uint256[] r) { r = new uint256[](2); r[0] = _a; r[1] = _b; } function arr(uint256 _a, uint256 _b, uint256 _c) internal pure returns (uint256[] r) { r = new uint256[](3); r[0] = _a; r[1] = _b; r[2] = _c; } function arr(uint256 _a, uint256 _b, uint256 _c, uint256 _d) internal pure returns (uint256[] r) { r = new uint256[](4); r[0] = _a; r[1] = _b; r[2] = _c; r[3] = _d; } function arr(uint256 _a, uint256 _b, uint256 _c, uint256 _d, uint256 _e) internal pure returns (uint256[] r) { r = new uint256[](5); r[0] = _a; r[1] = _b; r[2] = _c; r[3] = _d; r[4] = _e; } } contract ACLHelpers { function decodeParamOp(uint256 _x) internal pure returns (uint8 b) { return uint8(_x >> (8 * 30)); } function decodeParamId(uint256 _x) internal pure returns (uint8 b) { return uint8(_x >> (8 * 31)); } function decodeParamsList(uint256 _x) internal pure returns (uint32 a, uint32 b, uint32 c) { a = uint32(_x); b = uint32(_x >> (8 * 4)); c = uint32(_x >> (8 * 8)); } } // File @aragon/os/contracts/common/[email protected] pragma solidity ^0.4.24; library Uint256Helpers { uint256 private constant MAX_UINT64 = uint64(-1); string private constant ERROR_NUMBER_TOO_BIG = "UINT64_NUMBER_TOO_BIG"; function toUint64(uint256 a) internal pure returns (uint64) { require(a <= MAX_UINT64, ERROR_NUMBER_TOO_BIG); return uint64(a); } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract TimeHelpers { using Uint256Helpers for uint256; /** * @dev Returns the current block number. * Using a function rather than `block.number` allows us to easily mock the block number in * tests. */ function getBlockNumber() internal view returns (uint256) { return block.number; } /** * @dev Returns the current block number, converted to uint64. * Using a function rather than `block.number` allows us to easily mock the block number in * tests. */ function getBlockNumber64() internal view returns (uint64) { return getBlockNumber().toUint64(); } /** * @dev Returns the current timestamp. * Using a function rather than `block.timestamp` allows us to easily mock it in * tests. */ function getTimestamp() internal view returns (uint256) { return block.timestamp; // solium-disable-line security/no-block-members } /** * @dev Returns the current timestamp, converted to uint64. * Using a function rather than `block.timestamp` allows us to easily mock it in * tests. */ function getTimestamp64() internal view returns (uint64) { return getTimestamp().toUint64(); } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract Initializable is TimeHelpers { using UnstructuredStorage for bytes32; // keccak256("aragonOS.initializable.initializationBlock") bytes32 internal constant INITIALIZATION_BLOCK_POSITION = 0xebb05b386a8d34882b8711d156f463690983dc47815980fb82aeeff1aa43579e; string private constant ERROR_ALREADY_INITIALIZED = "INIT_ALREADY_INITIALIZED"; string private constant ERROR_NOT_INITIALIZED = "INIT_NOT_INITIALIZED"; modifier onlyInit { require(getInitializationBlock() == 0, ERROR_ALREADY_INITIALIZED); _; } modifier isInitialized { require(hasInitialized(), ERROR_NOT_INITIALIZED); _; } /** * @return Block number in which the contract was initialized */ function getInitializationBlock() public view returns (uint256) { return INITIALIZATION_BLOCK_POSITION.getStorageUint256(); } /** * @return Whether the contract has been initialized by the time of the current block */ function hasInitialized() public view returns (bool) { uint256 initializationBlock = getInitializationBlock(); return initializationBlock != 0 && getBlockNumber() >= initializationBlock; } /** * @dev Function to be called by top level contract after initialization has finished. */ function initialized() internal onlyInit { INITIALIZATION_BLOCK_POSITION.setStorageUint256(getBlockNumber()); } /** * @dev Function to be called by top level contract after initialization to enable the contract * at a future block number rather than immediately. */ function initializedAt(uint256 _blockNumber) internal onlyInit { INITIALIZATION_BLOCK_POSITION.setStorageUint256(_blockNumber); } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract Petrifiable is Initializable { // Use block UINT256_MAX (which should be never) as the initializable date uint256 internal constant PETRIFIED_BLOCK = uint256(-1); function isPetrified() public view returns (bool) { return getInitializationBlock() == PETRIFIED_BLOCK; } /** * @dev Function to be called by top level contract to prevent being initialized. * Useful for freezing base contracts when they're used behind proxies. */ function petrify() internal onlyInit { initializedAt(PETRIFIED_BLOCK); } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract Autopetrified is Petrifiable { constructor() public { // Immediately petrify base (non-proxy) instances of inherited contracts on deploy. // This renders them uninitializable (and unusable without a proxy). petrify(); } } // File @aragon/os/contracts/common/[email protected] pragma solidity ^0.4.24; library ConversionHelpers { string private constant ERROR_IMPROPER_LENGTH = "CONVERSION_IMPROPER_LENGTH"; function dangerouslyCastUintArrayToBytes(uint256[] memory _input) internal pure returns (bytes memory output) { // Force cast the uint256[] into a bytes array, by overwriting its length // Note that the bytes array doesn't need to be initialized as we immediately overwrite it // with the input and a new length. The input becomes invalid from this point forward. uint256 byteLength = _input.length * 32; assembly { output := _input mstore(output, byteLength) } } function dangerouslyCastBytesToUintArray(bytes memory _input) internal pure returns (uint256[] memory output) { // Force cast the bytes array into a uint256[], by overwriting its length // Note that the uint256[] doesn't need to be initialized as we immediately overwrite it // with the input and a new length. The input becomes invalid from this point forward. uint256 intsLength = _input.length / 32; require(_input.length == intsLength * 32, ERROR_IMPROPER_LENGTH); assembly { output := _input mstore(output, intsLength) } } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract ReentrancyGuard { using UnstructuredStorage for bytes32; /* Hardcoded constants to save gas bytes32 internal constant REENTRANCY_MUTEX_POSITION = keccak256("aragonOS.reentrancyGuard.mutex"); */ bytes32 private constant REENTRANCY_MUTEX_POSITION = 0xe855346402235fdd185c890e68d2c4ecad599b88587635ee285bce2fda58dacb; string private constant ERROR_REENTRANT = "REENTRANCY_REENTRANT_CALL"; modifier nonReentrant() { // Ensure mutex is unlocked require(!REENTRANCY_MUTEX_POSITION.getStorageBool(), ERROR_REENTRANT); // Lock mutex before function call REENTRANCY_MUTEX_POSITION.setStorageBool(true); // Perform function call _; // Unlock mutex after function call REENTRANCY_MUTEX_POSITION.setStorageBool(false); } } // File @aragon/os/contracts/lib/token/[email protected] // See https://github.com/OpenZeppelin/openzeppelin-solidity/blob/a9f910d34f0ab33a1ae5e714f69f9596a02b4d91/contracts/token/ERC20/ERC20.sol pragma solidity ^0.4.24; /** * @title ERC20 interface * @dev see https://github.com/ethereum/EIPs/issues/20 */ contract ERC20 { function totalSupply() public view returns (uint256); function balanceOf(address _who) public view returns (uint256); function allowance(address _owner, address _spender) public view returns (uint256); function transfer(address _to, uint256 _value) public returns (bool); function approve(address _spender, uint256 _value) public returns (bool); function transferFrom(address _from, address _to, uint256 _value) public returns (bool); event Transfer( address indexed from, address indexed to, uint256 value ); event Approval( address indexed owner, address indexed spender, uint256 value ); } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; // aragonOS and aragon-apps rely on address(0) to denote native ETH, in // contracts where both tokens and ETH are accepted contract EtherTokenConstant { address internal constant ETH = address(0); } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract IsContract { /* * NOTE: this should NEVER be used for authentication * (see pitfalls: https://github.com/fergarrui/ethereum-security/tree/master/contracts/extcodesize). * * This is only intended to be used as a sanity check that an address is actually a contract, * RATHER THAN an address not being a contract. */ function isContract(address _target) internal view returns (bool) { if (_target == address(0)) { return false; } uint256 size; assembly { size := extcodesize(_target) } return size > 0; } } // File @aragon/os/contracts/common/[email protected] // Inspired by AdEx (https://github.com/AdExNetwork/adex-protocol-eth/blob/b9df617829661a7518ee10f4cb6c4108659dd6d5/contracts/libs/SafeERC20.sol) // and 0x (https://github.com/0xProject/0x-monorepo/blob/737d1dc54d72872e24abce5a1dbe1b66d35fa21a/contracts/protocol/contracts/protocol/AssetProxy/ERC20Proxy.sol#L143) pragma solidity ^0.4.24; library SafeERC20 { // Before 0.5, solidity has a mismatch between `address.transfer()` and `token.transfer()`: // https://github.com/ethereum/solidity/issues/3544 bytes4 private constant TRANSFER_SELECTOR = 0xa9059cbb; string private constant ERROR_TOKEN_BALANCE_REVERTED = "SAFE_ERC_20_BALANCE_REVERTED"; string private constant ERROR_TOKEN_ALLOWANCE_REVERTED = "SAFE_ERC_20_ALLOWANCE_REVERTED"; function invokeAndCheckSuccess(address _addr, bytes memory _calldata) private returns (bool) { bool ret; assembly { let ptr := mload(0x40) // free memory pointer let success := call( gas, // forward all gas _addr, // address 0, // no value add(_calldata, 0x20), // calldata start mload(_calldata), // calldata length ptr, // write output over free memory 0x20 // uint256 return ) if gt(success, 0) { // Check number of bytes returned from last function call switch returndatasize // No bytes returned: assume success case 0 { ret := 1 } // 32 bytes returned: check if non-zero case 0x20 { // Only return success if returned data was true // Already have output in ptr ret := eq(mload(ptr), 1) } // Not sure what was returned: don't mark as success default { } } } return ret; } function staticInvoke(address _addr, bytes memory _calldata) private view returns (bool, uint256) { bool success; uint256 ret; assembly { let ptr := mload(0x40) // free memory pointer success := staticcall( gas, // forward all gas _addr, // address add(_calldata, 0x20), // calldata start mload(_calldata), // calldata length ptr, // write output over free memory 0x20 // uint256 return ) if gt(success, 0) { ret := mload(ptr) } } return (success, ret); } /** * @dev Same as a standards-compliant ERC20.transfer() that never reverts (returns false). * Note that this makes an external call to the token. */ function safeTransfer(ERC20 _token, address _to, uint256 _amount) internal returns (bool) { bytes memory transferCallData = abi.encodeWithSelector( TRANSFER_SELECTOR, _to, _amount ); return invokeAndCheckSuccess(_token, transferCallData); } /** * @dev Same as a standards-compliant ERC20.transferFrom() that never reverts (returns false). * Note that this makes an external call to the token. */ function safeTransferFrom(ERC20 _token, address _from, address _to, uint256 _amount) internal returns (bool) { bytes memory transferFromCallData = abi.encodeWithSelector( _token.transferFrom.selector, _from, _to, _amount ); return invokeAndCheckSuccess(_token, transferFromCallData); } /** * @dev Same as a standards-compliant ERC20.approve() that never reverts (returns false). * Note that this makes an external call to the token. */ function safeApprove(ERC20 _token, address _spender, uint256 _amount) internal returns (bool) { bytes memory approveCallData = abi.encodeWithSelector( _token.approve.selector, _spender, _amount ); return invokeAndCheckSuccess(_token, approveCallData); } /** * @dev Static call into ERC20.balanceOf(). * Reverts if the call fails for some reason (should never fail). */ function staticBalanceOf(ERC20 _token, address _owner) internal view returns (uint256) { bytes memory balanceOfCallData = abi.encodeWithSelector( _token.balanceOf.selector, _owner ); (bool success, uint256 tokenBalance) = staticInvoke(_token, balanceOfCallData); require(success, ERROR_TOKEN_BALANCE_REVERTED); return tokenBalance; } /** * @dev Static call into ERC20.allowance(). * Reverts if the call fails for some reason (should never fail). */ function staticAllowance(ERC20 _token, address _owner, address _spender) internal view returns (uint256) { bytes memory allowanceCallData = abi.encodeWithSelector( _token.allowance.selector, _owner, _spender ); (bool success, uint256 allowance) = staticInvoke(_token, allowanceCallData); require(success, ERROR_TOKEN_ALLOWANCE_REVERTED); return allowance; } /** * @dev Static call into ERC20.totalSupply(). * Reverts if the call fails for some reason (should never fail). */ function staticTotalSupply(ERC20 _token) internal view returns (uint256) { bytes memory totalSupplyCallData = abi.encodeWithSelector(_token.totalSupply.selector); (bool success, uint256 totalSupply) = staticInvoke(_token, totalSupplyCallData); require(success, ERROR_TOKEN_ALLOWANCE_REVERTED); return totalSupply; } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract VaultRecoverable is IVaultRecoverable, EtherTokenConstant, IsContract { using SafeERC20 for ERC20; string private constant ERROR_DISALLOWED = "RECOVER_DISALLOWED"; string private constant ERROR_VAULT_NOT_CONTRACT = "RECOVER_VAULT_NOT_CONTRACT"; string private constant ERROR_TOKEN_TRANSFER_FAILED = "RECOVER_TOKEN_TRANSFER_FAILED"; /** * @notice Send funds to recovery Vault. This contract should never receive funds, * but in case it does, this function allows one to recover them. * @param _token Token balance to be sent to recovery vault. */ function transferToVault(address _token) external { require(allowRecoverability(_token), ERROR_DISALLOWED); address vault = getRecoveryVault(); require(isContract(vault), ERROR_VAULT_NOT_CONTRACT); uint256 balance; if (_token == ETH) { balance = address(this).balance; vault.transfer(balance); } else { ERC20 token = ERC20(_token); balance = token.staticBalanceOf(this); require(token.safeTransfer(vault, balance), ERROR_TOKEN_TRANSFER_FAILED); } emit RecoverToVault(vault, _token, balance); } /** * @dev By default deriving from AragonApp makes it recoverable * @param token Token address that would be recovered * @return bool whether the app allows the recovery */ function allowRecoverability(address token) public view returns (bool) { return true; } // Cast non-implemented interface to be public so we can use it internally function getRecoveryVault() public view returns (address); } // File @aragon/os/contracts/evmscript/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; interface IEVMScriptExecutor { function execScript(bytes script, bytes input, address[] blacklist) external returns (bytes); function executorType() external pure returns (bytes32); } // File @aragon/os/contracts/evmscript/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract EVMScriptRegistryConstants { /* Hardcoded constants to save gas bytes32 internal constant EVMSCRIPT_REGISTRY_APP_ID = apmNamehash("evmreg"); */ bytes32 internal constant EVMSCRIPT_REGISTRY_APP_ID = 0xddbcfd564f642ab5627cf68b9b7d374fb4f8a36e941a75d89c87998cef03bd61; } interface IEVMScriptRegistry { function addScriptExecutor(IEVMScriptExecutor executor) external returns (uint id); function disableScriptExecutor(uint256 executorId) external; // TODO: this should be external // See https://github.com/ethereum/solidity/issues/4832 function getScriptExecutor(bytes script) public view returns (IEVMScriptExecutor); } // File @aragon/os/contracts/kernel/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract KernelAppIds { /* Hardcoded constants to save gas bytes32 internal constant KERNEL_CORE_APP_ID = apmNamehash("kernel"); bytes32 internal constant KERNEL_DEFAULT_ACL_APP_ID = apmNamehash("acl"); bytes32 internal constant KERNEL_DEFAULT_VAULT_APP_ID = apmNamehash("vault"); */ bytes32 internal constant KERNEL_CORE_APP_ID = 0x3b4bf6bf3ad5000ecf0f989d5befde585c6860fea3e574a4fab4c49d1c177d9c; bytes32 internal constant KERNEL_DEFAULT_ACL_APP_ID = 0xe3262375f45a6e2026b7e7b18c2b807434f2508fe1a2a3dfb493c7df8f4aad6a; bytes32 internal constant KERNEL_DEFAULT_VAULT_APP_ID = 0x7e852e0fcfce6551c13800f1e7476f982525c2b5277ba14b24339c68416336d1; } contract KernelNamespaceConstants { /* Hardcoded constants to save gas bytes32 internal constant KERNEL_CORE_NAMESPACE = keccak256("core"); bytes32 internal constant KERNEL_APP_BASES_NAMESPACE = keccak256("base"); bytes32 internal constant KERNEL_APP_ADDR_NAMESPACE = keccak256("app"); */ bytes32 internal constant KERNEL_CORE_NAMESPACE = 0xc681a85306374a5ab27f0bbc385296a54bcd314a1948b6cf61c4ea1bc44bb9f8; bytes32 internal constant KERNEL_APP_BASES_NAMESPACE = 0xf1f3eb40f5bc1ad1344716ced8b8a0431d840b5783aea1fd01786bc26f35ac0f; bytes32 internal constant KERNEL_APP_ADDR_NAMESPACE = 0xd6f028ca0e8edb4a8c9757ca4fdccab25fa1e0317da1188108f7d2dee14902fb; } // File @aragon/os/contracts/evmscript/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; contract EVMScriptRunner is AppStorage, Initializable, EVMScriptRegistryConstants, KernelNamespaceConstants { string private constant ERROR_EXECUTOR_UNAVAILABLE = "EVMRUN_EXECUTOR_UNAVAILABLE"; string private constant ERROR_PROTECTED_STATE_MODIFIED = "EVMRUN_PROTECTED_STATE_MODIFIED"; /* This is manually crafted in assembly string private constant ERROR_EXECUTOR_INVALID_RETURN = "EVMRUN_EXECUTOR_INVALID_RETURN"; */ event ScriptResult(address indexed executor, bytes script, bytes input, bytes returnData); function getEVMScriptExecutor(bytes _script) public view returns (IEVMScriptExecutor) { return IEVMScriptExecutor(getEVMScriptRegistry().getScriptExecutor(_script)); } function getEVMScriptRegistry() public view returns (IEVMScriptRegistry) { address registryAddr = kernel().getApp(KERNEL_APP_ADDR_NAMESPACE, EVMSCRIPT_REGISTRY_APP_ID); return IEVMScriptRegistry(registryAddr); } function runScript(bytes _script, bytes _input, address[] _blacklist) internal isInitialized protectState returns (bytes) { IEVMScriptExecutor executor = getEVMScriptExecutor(_script); require(address(executor) != address(0), ERROR_EXECUTOR_UNAVAILABLE); bytes4 sig = executor.execScript.selector; bytes memory data = abi.encodeWithSelector(sig, _script, _input, _blacklist); bytes memory output; assembly { let success := delegatecall( gas, // forward all gas executor, // address add(data, 0x20), // calldata start mload(data), // calldata length 0, // don't write output (we'll handle this ourselves) 0 // don't write output ) output := mload(0x40) // free mem ptr get switch success case 0 { // If the call errored, forward its full error data returndatacopy(output, 0, returndatasize) revert(output, returndatasize) } default { switch gt(returndatasize, 0x3f) case 0 { // Need at least 0x40 bytes returned for properly ABI-encoded bytes values, // revert with "EVMRUN_EXECUTOR_INVALID_RETURN" // See remix: doing a `revert("EVMRUN_EXECUTOR_INVALID_RETURN")` always results in // this memory layout mstore(output, 0x08c379a000000000000000000000000000000000000000000000000000000000) // error identifier mstore(add(output, 0x04), 0x0000000000000000000000000000000000000000000000000000000000000020) // starting offset mstore(add(output, 0x24), 0x000000000000000000000000000000000000000000000000000000000000001e) // reason length mstore(add(output, 0x44), 0x45564d52554e5f4558454355544f525f494e56414c49445f52455455524e0000) // reason revert(output, 100) // 100 = 4 + 3 * 32 (error identifier + 3 words for the ABI encoded error) } default { // Copy result // // Needs to perform an ABI decode for the expected `bytes` return type of // `executor.execScript()` as solidity will automatically ABI encode the returned bytes as: // [ position of the first dynamic length return value = 0x20 (32 bytes) ] // [ output length (32 bytes) ] // [ output content (N bytes) ] // // Perform the ABI decode by ignoring the first 32 bytes of the return data let copysize := sub(returndatasize, 0x20) returndatacopy(output, 0x20, copysize) mstore(0x40, add(output, copysize)) // free mem ptr set } } } emit ScriptResult(address(executor), _script, _input, output); return output; } modifier protectState { address preKernel = address(kernel()); bytes32 preAppId = appId(); _; // exec require(address(kernel()) == preKernel, ERROR_PROTECTED_STATE_MODIFIED); require(appId() == preAppId, ERROR_PROTECTED_STATE_MODIFIED); } } // File @aragon/os/contracts/apps/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; // Contracts inheriting from AragonApp are, by default, immediately petrified upon deployment so // that they can never be initialized. // Unless overriden, this behaviour enforces those contracts to be usable only behind an AppProxy. // ReentrancyGuard, EVMScriptRunner, and ACLSyntaxSugar are not directly used by this contract, but // are included so that they are automatically usable by subclassing contracts contract AragonApp is AppStorage, Autopetrified, VaultRecoverable, ReentrancyGuard, EVMScriptRunner, ACLSyntaxSugar { string private constant ERROR_AUTH_FAILED = "APP_AUTH_FAILED"; modifier auth(bytes32 _role) { require(canPerform(msg.sender, _role, new uint256[](0)), ERROR_AUTH_FAILED); _; } modifier authP(bytes32 _role, uint256[] _params) { require(canPerform(msg.sender, _role, _params), ERROR_AUTH_FAILED); _; } /** * @dev Check whether an action can be performed by a sender for a particular role on this app * @param _sender Sender of the call * @param _role Role on this app * @param _params Permission params for the role * @return Boolean indicating whether the sender has the permissions to perform the action. * Always returns false if the app hasn't been initialized yet. */ function canPerform(address _sender, bytes32 _role, uint256[] _params) public view returns (bool) { if (!hasInitialized()) { return false; } IKernel linkedKernel = kernel(); if (address(linkedKernel) == address(0)) { return false; } return linkedKernel.hasPermission( _sender, address(this), _role, ConversionHelpers.dangerouslyCastUintArrayToBytes(_params) ); } /** * @dev Get the recovery vault for the app * @return Recovery vault address for the app */ function getRecoveryVault() public view returns (address) { // Funds recovery via a vault is only available when used with a kernel return kernel().getRecoveryVault(); // if kernel is not set, it will revert } } // File @aragon/os/contracts/common/[email protected] /* * SPDX-License-Identifier: MIT */ pragma solidity ^0.4.24; interface IForwarder { function isForwarder() external pure returns (bool); // TODO: this should be external // See https://github.com/ethereum/solidity/issues/4832 function canForward(address sender, bytes evmCallScript) public view returns (bool); // TODO: this should be external // See https://github.com/ethereum/solidity/issues/4832 function forward(bytes evmCallScript) public; } // File @aragon/os/contracts/lib/math/[email protected] // See https://github.com/OpenZeppelin/openzeppelin-solidity/blob/d51e38758e1d985661534534d5c61e27bece5042/contracts/math/SafeMath.sol // Adapted to use pragma ^0.4.24 and satisfy our linter rules pragma solidity ^0.4.24; /** * @title SafeMath * @dev Math operations with safety checks that revert on error */ library SafeMath { string private constant ERROR_ADD_OVERFLOW = "MATH_ADD_OVERFLOW"; string private constant ERROR_SUB_UNDERFLOW = "MATH_SUB_UNDERFLOW"; string private constant ERROR_MUL_OVERFLOW = "MATH_MUL_OVERFLOW"; string private constant ERROR_DIV_ZERO = "MATH_DIV_ZERO"; /** * @dev Multiplies two numbers, reverts on overflow. */ function mul(uint256 _a, uint256 _b) internal pure returns (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-solidity/pull/522 if (_a == 0) { return 0; } uint256 c = _a * _b; require(c / _a == _b, ERROR_MUL_OVERFLOW); return c; } /** * @dev Integer division of two numbers truncating the quotient, reverts on division by zero. */ function div(uint256 _a, uint256 _b) internal pure returns (uint256) { require(_b > 0, ERROR_DIV_ZERO); // Solidity only automatically asserts when dividing by 0 uint256 c = _a / _b; // assert(_a == _b * c + _a % _b); // There is no case in which this doesn't hold return c; } /** * @dev Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend). */ function sub(uint256 _a, uint256 _b) internal pure returns (uint256) { require(_b <= _a, ERROR_SUB_UNDERFLOW); uint256 c = _a - _b; return c; } /** * @dev Adds two numbers, reverts on overflow. */ function add(uint256 _a, uint256 _b) internal pure returns (uint256) { uint256 c = _a + _b; require(c >= _a, ERROR_ADD_OVERFLOW); return c; } /** * @dev Divides two numbers and returns the remainder (unsigned integer modulo), * reverts when dividing by zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { require(b != 0, ERROR_DIV_ZERO); return a % b; } } // File @aragon/os/contracts/lib/math/[email protected] // See https://github.com/OpenZeppelin/openzeppelin-solidity/blob/d51e38758e1d985661534534d5c61e27bece5042/contracts/math/SafeMath.sol // Adapted for uint64, pragma ^0.4.24, and satisfying our linter rules // Also optimized the mul() implementation, see https://github.com/aragon/aragonOS/pull/417 pragma solidity ^0.4.24; /** * @title SafeMath64 * @dev Math operations for uint64 with safety checks that revert on error */ library SafeMath64 { string private constant ERROR_ADD_OVERFLOW = "MATH64_ADD_OVERFLOW"; string private constant ERROR_SUB_UNDERFLOW = "MATH64_SUB_UNDERFLOW"; string private constant ERROR_MUL_OVERFLOW = "MATH64_MUL_OVERFLOW"; string private constant ERROR_DIV_ZERO = "MATH64_DIV_ZERO"; /** * @dev Multiplies two numbers, reverts on overflow. */ function mul(uint64 _a, uint64 _b) internal pure returns (uint64) { uint256 c = uint256(_a) * uint256(_b); require(c < 0x010000000000000000, ERROR_MUL_OVERFLOW); // 2**64 (less gas this way) return uint64(c); } /** * @dev Integer division of two numbers truncating the quotient, reverts on division by zero. */ function div(uint64 _a, uint64 _b) internal pure returns (uint64) { require(_b > 0, ERROR_DIV_ZERO); // Solidity only automatically asserts when dividing by 0 uint64 c = _a / _b; // assert(_a == _b * c + _a % _b); // There is no case in which this doesn't hold return c; } /** * @dev Subtracts two numbers, reverts on overflow (i.e. if subtrahend is greater than minuend). */ function sub(uint64 _a, uint64 _b) internal pure returns (uint64) { require(_b <= _a, ERROR_SUB_UNDERFLOW); uint64 c = _a - _b; return c; } /** * @dev Adds two numbers, reverts on overflow. */ function add(uint64 _a, uint64 _b) internal pure returns (uint64) { uint64 c = _a + _b; require(c >= _a, ERROR_ADD_OVERFLOW); return c; } /** * @dev Divides two numbers and returns the remainder (unsigned integer modulo), * reverts when dividing by zero. */ function mod(uint64 a, uint64 b) internal pure returns (uint64) { require(b != 0, ERROR_DIV_ZERO); return a % b; } } // File @aragon/apps-shared-minime/contracts/[email protected] pragma solidity ^0.4.24; /// @dev The token controller contract must implement these functions interface ITokenController { /// @notice Called when `_owner` sends ether to the MiniMe Token contract /// @param _owner The address that sent the ether to create tokens /// @return True if the ether is accepted, false if it throws function proxyPayment(address _owner) external payable returns(bool); /// @notice Notifies the controller about a token transfer allowing the /// controller to react if desired /// @param _from The origin of the transfer /// @param _to The destination of the transfer /// @param _amount The amount of the transfer /// @return False if the controller does not authorize the transfer function onTransfer(address _from, address _to, uint _amount) external returns(bool); /// @notice Notifies the controller about an approval allowing the /// controller to react if desired /// @param _owner The address that calls `approve()` /// @param _spender The spender in the `approve()` call /// @param _amount The amount in the `approve()` call /// @return False if the controller does not authorize the approval function onApprove(address _owner, address _spender, uint _amount) external returns(bool); } // File @aragon/apps-shared-minime/contracts/[email protected] pragma solidity ^0.4.24; /* Copyright 2016, Jordi Baylina This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ /// @title MiniMeToken Contract /// @author Jordi Baylina /// @dev This token contract's goal is to make it easy for anyone to clone this /// token using the token distribution at a given block, this will allow DAO's /// and DApps to upgrade their features in a decentralized manner without /// affecting the original token /// @dev It is ERC20 compliant, but still needs to under go further testing. contract Controlled { /// @notice The address of the controller is the only address that can call /// a function with this modifier modifier onlyController { require(msg.sender == controller); _; } address public controller; function Controlled() public { controller = msg.sender;} /// @notice Changes the controller of the contract /// @param _newController The new controller of the contract function changeController(address _newController) onlyController public { controller = _newController; } } contract ApproveAndCallFallBack { function receiveApproval( address from, uint256 _amount, address _token, bytes _data ) public; } /// @dev The actual token contract, the default controller is the msg.sender /// that deploys the contract, so usually this token will be deployed by a /// token controller contract, which Giveth will call a "Campaign" contract MiniMeToken is Controlled { string public name; //The Token's name: e.g. DigixDAO Tokens uint8 public decimals; //Number of decimals of the smallest unit string public symbol; //An identifier: e.g. REP string public version = "MMT_0.1"; //An arbitrary versioning scheme /// @dev `Checkpoint` is the structure that attaches a block number to a /// given value, the block number attached is the one that last changed the /// value struct Checkpoint { // `fromBlock` is the block number that the value was generated from uint128 fromBlock; // `value` is the amount of tokens at a specific block number uint128 value; } // `parentToken` is the Token address that was cloned to produce this token; // it will be 0x0 for a token that was not cloned MiniMeToken public parentToken; // `parentSnapShotBlock` is the block number from the Parent Token that was // used to determine the initial distribution of the Clone Token uint public parentSnapShotBlock; // `creationBlock` is the block number that the Clone Token was created uint public creationBlock; // `balances` is the map that tracks the balance of each address, in this // contract when the balance changes the block number that the change // occurred is also included in the map mapping (address => Checkpoint[]) balances; // `allowed` tracks any extra transfer rights as in all ERC20 tokens mapping (address => mapping (address => uint256)) allowed; // Tracks the history of the `totalSupply` of the token Checkpoint[] totalSupplyHistory; // Flag that determines if the token is transferable or not. bool public transfersEnabled; // The factory used to create new clone tokens MiniMeTokenFactory public tokenFactory; //////////////// // Constructor //////////////// /// @notice Constructor to create a MiniMeToken /// @param _tokenFactory The address of the MiniMeTokenFactory contract that /// will create the Clone token contracts, the token factory needs to be /// deployed first /// @param _parentToken Address of the parent token, set to 0x0 if it is a /// new token /// @param _parentSnapShotBlock Block of the parent token that will /// determine the initial distribution of the clone token, set to 0 if it /// is a new token /// @param _tokenName Name of the new token /// @param _decimalUnits Number of decimals of the new token /// @param _tokenSymbol Token Symbol for the new token /// @param _transfersEnabled If true, tokens will be able to be transferred function MiniMeToken( MiniMeTokenFactory _tokenFactory, MiniMeToken _parentToken, uint _parentSnapShotBlock, string _tokenName, uint8 _decimalUnits, string _tokenSymbol, bool _transfersEnabled ) public { tokenFactory = _tokenFactory; name = _tokenName; // Set the name decimals = _decimalUnits; // Set the decimals symbol = _tokenSymbol; // Set the symbol parentToken = _parentToken; parentSnapShotBlock = _parentSnapShotBlock; transfersEnabled = _transfersEnabled; creationBlock = block.number; } /////////////////// // ERC20 Methods /////////////////// /// @notice Send `_amount` tokens to `_to` from `msg.sender` /// @param _to The address of the recipient /// @param _amount The amount of tokens to be transferred /// @return Whether the transfer was successful or not function transfer(address _to, uint256 _amount) public returns (bool success) { require(transfersEnabled); return doTransfer(msg.sender, _to, _amount); } /// @notice Send `_amount` tokens to `_to` from `_from` on the condition it /// is approved by `_from` /// @param _from The address holding the tokens being transferred /// @param _to The address of the recipient /// @param _amount The amount of tokens to be transferred /// @return True if the transfer was successful function transferFrom(address _from, address _to, uint256 _amount) public returns (bool success) { // The controller of this contract can move tokens around at will, // this is important to recognize! Confirm that you trust the // controller of this contract, which in most situations should be // another open source smart contract or 0x0 if (msg.sender != controller) { require(transfersEnabled); // The standard ERC 20 transferFrom functionality if (allowed[_from][msg.sender] < _amount) return false; allowed[_from][msg.sender] -= _amount; } return doTransfer(_from, _to, _amount); } /// @dev This is the actual transfer function in the token contract, it can /// only be called by other functions in this contract. /// @param _from The address holding the tokens being transferred /// @param _to The address of the recipient /// @param _amount The amount of tokens to be transferred /// @return True if the transfer was successful function doTransfer(address _from, address _to, uint _amount) internal returns(bool) { if (_amount == 0) { return true; } require(parentSnapShotBlock < block.number); // Do not allow transfer to 0x0 or the token contract itself require((_to != 0) && (_to != address(this))); // If the amount being transfered is more than the balance of the // account the transfer returns false var previousBalanceFrom = balanceOfAt(_from, block.number); if (previousBalanceFrom < _amount) { return false; } // Alerts the token controller of the transfer if (isContract(controller)) { //... // [truncated — 90340 bytes total]
Read Contract
CREATE_VOTES_ROLE 0xbe2c64d4 → bytes32
DISABLE_VOTE_CREATION 0xff311838 → bytes32
ENABLE_VOTE_CREATION 0x868ce31a → bytes32
MODIFY_QUORUM_ROLE 0x3c624c75 → bytes32
MODIFY_SUPPORT_ROLE 0x62de7e5a → bytes32
PCT_BASE 0xfc157cb4 → uint64
SET_MIN_BALANCE_ROLE 0xb6f68254 → bytes32
SET_MIN_TIME_ROLE 0xc54c24b5 → bytes32
allowRecoverability 0x7e7db6e1 → bool
appId 0x80afdea8 → bytes32
canCreateNewVote 0x2d573501 → bool
canExecute 0xcc63604a → bool
canForward 0xc0774df3 → bool
canPerform 0xa1658fad → bool
canVote 0xcdb2867b → bool
enableVoteCreation 0xee0f160e → bool
getEVMScriptExecutor 0x2914b9bd → address
getEVMScriptRegistry 0xa479e508 → address
getInitializationBlock 0x8b3dd749 → uint256
getRecoveryVault 0x32f0a3b5 → address
getVote 0x5a55c1f0 → bool, bool, uint64, uint64, uint64, uint64, uint256, uint256, uint256, bytes
getVoterState 0x4b12311c → uint8
hasInitialized 0x0803fac0 → bool
isForwarder 0xfd64eccb → bool
isPetrified 0xde4796ed → bool
kernel 0xd4aae0c4 → address
lastCreateVoteTimes 0x7bbddcfc → uint256
minAcceptQuorumPct 0xdc474b1a → uint64
minBalance 0xc5bb8758 → uint256
minBalanceLowerLimit 0xeb1e3b77 → uint256
minBalanceUpperLimit 0x8b568327 → uint256
minTime 0x1aa43078 → uint256
minTimeLowerLimit 0xb8795725 → uint256
minTimeUpperLimit 0xdf352197 → uint256
supportRequiredPct 0xfad167ab → uint64
token 0xfc0c546a → address
voteTime 0xbcf93dd6 → uint64
votesLength 0xde4f6347 → uint256
Write Contract 14 functions
These functions modify contract state and require a wallet transaction to execute.
changeMinAcceptQuorumPct 0x5eb24332
uint64 _minAcceptQuorumPct
changeSupportRequiredPct 0x7c1d0b87
uint64 _supportRequiredPct
disableVoteCreationOnce 0xdc177eec
No parameters
enableVoteCreationOnce 0xdf136602
No parameters
executeVote 0xf98a4eca
uint256 _voteId
forward 0xd948d468
bytes _evmScript
initialize 0xa87f8624
address _token
uint64 _supportRequiredPct
uint64 _minAcceptQuorumPct
uint64 _voteTime
uint256 _minBalance
uint256 _minTime
uint256 _minBalanceLowerLimit
uint256 _minBalanceUpperLimit
uint256 _minTimeLowerLimit
uint256 _minTimeUpperLimit
newVote 0xd5db2c80
bytes _executionScript
string _metadata
returns: uint256
newVote 0xf4b00513
bytes _executionScript
string _metadata
bool _castVote
bool _executesIfDecided
returns: uint256
setMinBalance 0xc91d956c
uint256 _minBalance
setMinTime 0x93f89a80
uint256 _minTime
transferToVault 0x9d4941d8
address _token
vote 0xdf133bca
uint256 _voteData
bool _supports
bool _executesIfDecided
votePct 0x1e526610
uint256 _voteId
uint256 _yeaPct
uint256 _nayPct
bool _executesIfDecided
Recent Transactions
This address has 1 on-chain transactions, but only 1.6% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →