@etherisc/gif-next 0.0.2-efef0ea-320 → 0.0.2-f02157b-803
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +144 -26
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +168 -28
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +259 -54
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +121 -28
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +0 -188
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +0 -238
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +0 -213
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +292 -96
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +388 -78
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +66 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +24 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +42 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.json +101 -0
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +1119 -0
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +4 -0
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +1082 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +116 -1813
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/InstanceBase.sol/InstanceBase.json → IInstanceService.sol/IInstanceService.json} +127 -169
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2238 -1251
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +917 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1257 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +703 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +424 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +144 -50
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +27 -158
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IService.sol/IService.json +120 -40
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +37 -245
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +140 -59
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +211 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{distribution/IDistribution.sol → IDistribution.sol}/IDistribution.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +295 -86
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +123 -62
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +120 -40
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +120 -40
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +120 -40
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +186 -12
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +190 -51
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +872 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +34 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +380 -139
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1261 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +504 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/component/ComponentModule.sol/ComponentModule.json → shared/INftOwnable.sol/INftOwnable.json} +67 -57
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +117 -37
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +158 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +349 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +190 -37
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/{Proxy.sol/ProxyWithProxyAdminGetter.json → UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json} +4 -4
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +4 -27
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +4 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +204 -36
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +14 -14
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +203 -69
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +91 -53
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +29 -36
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/test/Usdc.sol/USDC.json +91 -53
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +4 -4
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +31 -17
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +123 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +134 -8
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +15 -2
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/{UFixedMathLib.json → UFixedLib.json} +3 -3
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/BaseComponent.sol +20 -28
- package/contracts/components/Distribution.sol +54 -20
- package/contracts/components/IBaseComponent.sol +8 -3
- package/contracts/components/IDistributionComponent.sol +2 -6
- package/contracts/components/IPoolComponent.sol +2 -11
- package/contracts/components/IProductComponent.sol +4 -7
- package/contracts/components/Pool.sol +100 -76
- package/contracts/components/Product.sol +111 -41
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/instance/AccessManagedSimple.sol +114 -0
- package/contracts/instance/AccessManagerSimple.sol +682 -0
- package/contracts/instance/IAccessManagerSimple.sol +391 -0
- package/contracts/instance/IInstance.sol +17 -42
- package/contracts/instance/IInstanceService.sol +17 -0
- package/contracts/instance/Instance.sol +421 -59
- package/contracts/instance/InstanceAccessManager.sol +288 -0
- package/contracts/instance/InstanceReader.sol +280 -0
- package/contracts/instance/InstanceService.sol +102 -0
- package/contracts/instance/InstanceServiceManager.sol +56 -0
- package/contracts/instance/base/ComponentServiceBase.sol +13 -6
- package/contracts/instance/base/IInstanceBase.sol +3 -2
- package/contracts/instance/base/IKeyValueStore.sol +13 -14
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +49 -38
- package/contracts/instance/base/Lifecycle.sol +1 -1
- package/contracts/instance/base/ServiceBase.sol +20 -13
- package/contracts/instance/module/IAccess.sol +38 -0
- package/contracts/instance/module/IBundle.sol +19 -0
- package/contracts/instance/module/IDistribution.sol +39 -0
- package/contracts/instance/module/IPolicy.sol +45 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +43 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/ComponentOwnerService.sol +231 -71
- package/contracts/instance/service/IComponentOwnerService.sol +0 -2
- package/contracts/instance/service/IProductService.sol +2 -2
- package/contracts/registry/ChainNft.sol +80 -37
- package/contracts/registry/IRegistry.sol +28 -28
- package/contracts/registry/IRegistryService.sol +35 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +313 -271
- package/contracts/registry/RegistryService.sol +439 -0
- package/contracts/registry/RegistryServiceManager.sol +64 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/INftOwnable.sol +22 -0
- package/contracts/shared/IRegisterable.sol +8 -15
- package/contracts/shared/IVersionable.sol +46 -15
- package/contracts/shared/NftOwnable.sol +136 -0
- package/contracts/shared/ProxyManager.sol +94 -0
- package/contracts/shared/Registerable.sol +62 -59
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +110 -62
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestRoleId.sol +1 -1
- package/contracts/test/TestService.sol +5 -11
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +3 -3
- package/contracts/types/Key32.sol +8 -3
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +35 -14
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RoleId.sol +53 -9
- package/contracts/types/StateId.sol +1 -1
- package/contracts/types/Timestamp.sol +7 -3
- package/contracts/types/UFixed.sol +128 -12
- package/contracts/types/Version.sol +1 -0
- package/package.json +4 -3
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.json +0 -10
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -297
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -297
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -117
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +0 -10
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +0 -10
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -284
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -284
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -144
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -144
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -113
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -131
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -511
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -511
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -507
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -630
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -945
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -452
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.json +0 -724
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
- package/artifacts/contracts/shared/Proxy.sol/ProxyDeployer.dbg.json +0 -4
- package/artifacts/contracts/shared/Proxy.sol/ProxyDeployer.json +0 -248
- package/artifacts/contracts/shared/Proxy.sol/ProxyWithProxyAdminGetter.dbg.json +0 -4
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.dbg.json +0 -4
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.json +0 -228
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +0 -4
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +0 -405
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -578
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -575
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +0 -99
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/IInstanceLinked.sol +0 -8
- package/contracts/instance/base/InstanceBase.sol +0 -91
- package/contracts/instance/base/ModuleBase.sol +0 -57
- package/contracts/instance/module/access/Access.sol +0 -149
- package/contracts/instance/module/access/IAccess.sol +0 -53
- package/contracts/instance/module/bundle/BundleModule.sol +0 -134
- package/contracts/instance/module/bundle/IBundle.sol +0 -53
- package/contracts/instance/module/component/ComponentModule.sol +0 -70
- package/contracts/instance/module/component/IComponent.sol +0 -28
- package/contracts/instance/module/distribution/DistributionModule.sol +0 -17
- package/contracts/instance/module/distribution/IDistribution.sol +0 -10
- package/contracts/instance/module/policy/IPolicy.sol +0 -63
- package/contracts/instance/module/policy/PolicyModule.sol +0 -91
- package/contracts/instance/module/pool/IPoolModule.sol +0 -40
- package/contracts/instance/module/pool/PoolModule.sol +0 -90
- package/contracts/instance/module/risk/IRisk.sol +0 -26
- package/contracts/instance/module/risk/RiskModule.sol +0 -62
- package/contracts/instance/module/treasury/ITreasury.sol +0 -82
- package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
- package/contracts/instance/module/treasury/TreasuryModule.sol +0 -138
- package/contracts/instance/service/DistributionService.sol +0 -59
- package/contracts/instance/service/PoolService.sol +0 -149
- package/contracts/instance/service/ProductService.sol +0 -509
- package/contracts/registry/IChainNft.sol +0 -21
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/registry/RegistryUpgradeable.sol +0 -488
- package/contracts/shared/IOwnable.sol +0 -6
- package/contracts/shared/Proxy.sol +0 -94
- package/contracts/shared/VersionableUpgradeable.sol +0 -136
- package/contracts/test/TestDistribution.sol +0 -21
- package/contracts/test/TestPool.sol +0 -25
- package/contracts/test/TestProduct.sol +0 -72
- package/contracts/types/ReferralId.sol +0 -48
@@ -1,99 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"_format": "hh-sol-artifact-1",
|
3
|
-
"contractName": "ReferralIdLib",
|
4
|
-
"sourceName": "contracts/types/ReferralId.sol",
|
5
|
-
"abi": [
|
6
|
-
{
|
7
|
-
"inputs": [
|
8
|
-
{
|
9
|
-
"internalType": "ReferralId",
|
10
|
-
"name": "id",
|
11
|
-
"type": "bytes8"
|
12
|
-
}
|
13
|
-
],
|
14
|
-
"name": "toKey32",
|
15
|
-
"outputs": [
|
16
|
-
{
|
17
|
-
"internalType": "Key32",
|
18
|
-
"name": "key",
|
19
|
-
"type": "bytes32"
|
20
|
-
}
|
21
|
-
],
|
22
|
-
"stateMutability": "pure",
|
23
|
-
"type": "function"
|
24
|
-
},
|
25
|
-
{
|
26
|
-
"inputs": [
|
27
|
-
{
|
28
|
-
"internalType": "ReferralId",
|
29
|
-
"name": "id",
|
30
|
-
"type": "bytes8"
|
31
|
-
}
|
32
|
-
],
|
33
|
-
"name": "toKeyId",
|
34
|
-
"outputs": [
|
35
|
-
{
|
36
|
-
"internalType": "KeyId",
|
37
|
-
"name": "keyId",
|
38
|
-
"type": "bytes31"
|
39
|
-
}
|
40
|
-
],
|
41
|
-
"stateMutability": "pure",
|
42
|
-
"type": "function"
|
43
|
-
},
|
44
|
-
{
|
45
|
-
"inputs": [
|
46
|
-
{
|
47
|
-
"internalType": "string",
|
48
|
-
"name": "referral",
|
49
|
-
"type": "string"
|
50
|
-
}
|
51
|
-
],
|
52
|
-
"name": "toReferralId",
|
53
|
-
"outputs": [
|
54
|
-
{
|
55
|
-
"internalType": "ReferralId",
|
56
|
-
"name": "",
|
57
|
-
"type": "bytes8"
|
58
|
-
}
|
59
|
-
],
|
60
|
-
"stateMutability": "pure",
|
61
|
-
"type": "function"
|
62
|
-
},
|
63
|
-
{
|
64
|
-
"inputs": [],
|
65
|
-
"name": "zeroReferralId",
|
66
|
-
"outputs": [
|
67
|
-
{
|
68
|
-
"internalType": "ReferralId",
|
69
|
-
"name": "",
|
70
|
-
"type": "bytes8"
|
71
|
-
}
|
72
|
-
],
|
73
|
-
"stateMutability": "pure",
|
74
|
-
"type": "function"
|
75
|
-
}
|
76
|
-
],
|
77
|
-
"bytecode": "0x61034161003a600b82828239805160001a60731461002d57634e487b7160e01b600052600060045260246000fd5b30600052607381538281f3fe73000000000000000000000000000000000000000030146080604052600436106100565760003560e01c806317130acc1461005b5780632cf96bf91461008c57806355ee6275146100ba578063f77d70c8146100db575b600080fd5b61006e6100693660046101c2565b6100e2565b6040516001600160c01b031990911681526020015b60405180910390f35b6100a761009a366004610273565b6001600160c01b03191690565b60405160ff199091168152602001610083565b6100cd6100c8366004610273565b610112565b604051908152602001610083565b600061006e565b6000816040516020016100f591906102a4565b604051602081830303815290604052805190602001209050919050565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce60d46001600160c01b031985166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af4158015610182573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906101a691906102f2565b92915050565b634e487b7160e01b600052604160045260246000fd5b6000602082840312156101d457600080fd5b813567ffffffffffffffff808211156101ec57600080fd5b818401915084601f83011261020057600080fd5b813581811115610212576102126101ac565b604051601f8201601f19908116603f0116810190838211818310171561023a5761023a6101ac565b8160405282815287602084870101111561025357600080fd5b826020860160208301376000928101602001929092525095945050505050565b60006020828403121561028557600080fd5b81356001600160c01b03198116811461029d57600080fd5b9392505050565b600060208083528351808285015260005b818110156102d1578581018301518582016040015282016102b5565b506000604082860101526040601f19601f8301168501019250505092915050565b60006020828403121561030457600080fd5b505191905056fea26469706673582212206f489a59a5ff949525bfa166f5c495acd31da1b2cef5254b93c44b7b7f271b0664736f6c63430008140033",
|
78
|
-
"deployedBytecode": "0x73000000000000000000000000000000000000000030146080604052600436106100565760003560e01c806317130acc1461005b5780632cf96bf91461008c57806355ee6275146100ba578063f77d70c8146100db575b600080fd5b61006e6100693660046101c2565b6100e2565b6040516001600160c01b031990911681526020015b60405180910390f35b6100a761009a366004610273565b6001600160c01b03191690565b60405160ff199091168152602001610083565b6100cd6100c8366004610273565b610112565b604051908152602001610083565b600061006e565b6000816040516020016100f591906102a4565b604051602081830303815290604052805190602001209050919050565b600073__$c8f743efd2b4f0c9300f2558c784479d3e$__63f48016ce60d46001600160c01b031985166040516001600160e01b031960e085901b16815260ff909216600483015260ff19166024820152604401602060405180830381865af4158015610182573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906101a691906102f2565b92915050565b634e487b7160e01b600052604160045260246000fd5b6000602082840312156101d457600080fd5b813567ffffffffffffffff808211156101ec57600080fd5b818401915084601f83011261020057600080fd5b813581811115610212576102126101ac565b604051601f8201601f19908116603f0116810190838211818310171561023a5761023a6101ac565b8160405282815287602084870101111561025357600080fd5b826020860160208301376000928101602001929092525095945050505050565b60006020828403121561028557600080fd5b81356001600160c01b03198116811461029d57600080fd5b9392505050565b600060208083528351808285015260005b818110156102d1578581018301518582016040015282016102b5565b506000604082860101526040601f19601f8301168501019250505092915050565b60006020828403121561030457600080fd5b505191905056fea26469706673582212206f489a59a5ff949525bfa166f5c495acd31da1b2cef5254b93c44b7b7f271b0664736f6c63430008140033",
|
79
|
-
"linkReferences": {
|
80
|
-
"contracts/types/Key32.sol": {
|
81
|
-
"Key32Lib": [
|
82
|
-
{
|
83
|
-
"length": 20,
|
84
|
-
"start": 336
|
85
|
-
}
|
86
|
-
]
|
87
|
-
}
|
88
|
-
},
|
89
|
-
"deployedLinkReferences": {
|
90
|
-
"contracts/types/Key32.sol": {
|
91
|
-
"Key32Lib": [
|
92
|
-
{
|
93
|
-
"length": 20,
|
94
|
-
"start": 278
|
95
|
-
}
|
96
|
-
]
|
97
|
-
}
|
98
|
-
}
|
99
|
-
}
|
@@ -1,112 +0,0 @@
|
|
1
|
-
# State Machines
|
2
|
-
|
3
|
-
Most GIF objects have a life cycle defined by a state machine.
|
4
|
-
|
5
|
-
For each object type the set of possible states is defined together with its initial state and the set of valid state transitions.
|
6
|
-
|
7
|
-
## Object Types without States
|
8
|
-
|
9
|
-
* Protocol
|
10
|
-
* Chains
|
11
|
-
* Registries (both chain and main registry)
|
12
|
-
|
13
|
-
## Object Types with States
|
14
|
-
|
15
|
-
* Tokens
|
16
|
-
* Instances
|
17
|
-
* Products
|
18
|
-
* Oracles
|
19
|
-
* Pools
|
20
|
-
* Bundles
|
21
|
-
* Policies
|
22
|
-
* Claim (non-NFT)
|
23
|
-
* Payout (non-NFT)
|
24
|
-
|
25
|
-
### Simple State Machine
|
26
|
-
|
27
|
-
Valid states
|
28
|
-
|
29
|
-
* Active (initial state)
|
30
|
-
* Paused
|
31
|
-
* Archived (final state)
|
32
|
-
|
33
|
-
Valid state transitions:
|
34
|
-
|
35
|
-
* Active -> Paused
|
36
|
-
* Paused -> Active
|
37
|
-
* Paused -> Archived
|
38
|
-
|
39
|
-
|
40
|
-
Candidate object types for simple state machine
|
41
|
-
|
42
|
-
* Token
|
43
|
-
* Instance
|
44
|
-
* Product
|
45
|
-
* Oracle
|
46
|
-
* Pool
|
47
|
-
|
48
|
-
To discuss:
|
49
|
-
|
50
|
-
* Archived is final state
|
51
|
-
* What mechanism should exist to revert an unintended transition to 'Archived' state. Should there be such a mechanism?
|
52
|
-
* What mechanism should exist when the NFT of such an object is burned prematurely. Should there be such a mechanism
|
53
|
-
|
54
|
-
### Bundle State Machine
|
55
|
-
|
56
|
-
Valid states
|
57
|
-
|
58
|
-
* Active (initial state)
|
59
|
-
* Paused
|
60
|
-
* Expired (implicit state)
|
61
|
-
* Closed (final state)
|
62
|
-
|
63
|
-
Expired is not an explicit state.
|
64
|
-
A bundle is expired for block.timestamp >= expiredAt
|
65
|
-
|
66
|
-
### Policy State Machine
|
67
|
-
|
68
|
-
Valid states
|
69
|
-
|
70
|
-
* Applied (initial state)
|
71
|
-
* Revoked (final state)
|
72
|
-
* Declined (final state)
|
73
|
-
* Active
|
74
|
-
* Expired (implicit state)
|
75
|
-
* Closed (final state)
|
76
|
-
|
77
|
-
Expired is not an explicit state.
|
78
|
-
A policy is expired for block.timestamp >= expiredAt
|
79
|
-
|
80
|
-
To discuss:
|
81
|
-
|
82
|
-
* Should 'Closed' be less explicit using a closedAt state variable?
|
83
|
-
* Or even more lighweight? ie. block.timestamp >= expiredAt and no open claims
|
84
|
-
|
85
|
-
Valid state transitions:
|
86
|
-
|
87
|
-
* Applied -> Revoked
|
88
|
-
* Applied -> Declined
|
89
|
-
* Applied -> Active
|
90
|
-
* Active -> Closed (needs to be expired)
|
91
|
-
|
92
|
-
### Claim State Machine
|
93
|
-
|
94
|
-
Valid states
|
95
|
-
* Applied (initial state)
|
96
|
-
* Confirmed
|
97
|
-
* Declined (final state)
|
98
|
-
* Closed (final state)
|
99
|
-
|
100
|
-
Valid state transitions:
|
101
|
-
* Applied -> Confirmed
|
102
|
-
* Applied -> Declined
|
103
|
-
* Confirmed -> Closed
|
104
|
-
|
105
|
-
### Payout State Machine
|
106
|
-
|
107
|
-
Valid states
|
108
|
-
* Expected
|
109
|
-
* PaidOut
|
110
|
-
|
111
|
-
Valid state transitions:
|
112
|
-
* Expected -> PaidOut
|
@@ -1,91 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {Versionable} from "../../shared/Versionable.sol";
|
5
|
-
import {Registerable} from "../../shared/Registerable.sol";
|
6
|
-
|
7
|
-
import {ObjectType, INSTANCE} from "../../types/ObjectType.sol";
|
8
|
-
import {Key32} from "../../types/Key32.sol";
|
9
|
-
import {NftId} from "../../types/NftId.sol";
|
10
|
-
import {StateId} from "../../types/StateId.sol";
|
11
|
-
import {Version, VersionPart, VersionLib} from "../../types/Version.sol";
|
12
|
-
|
13
|
-
import {IComponentOwnerService} from "../service/IComponentOwnerService.sol";
|
14
|
-
import {IDistributionService} from "../service/IDistributionService.sol";
|
15
|
-
import {IProductService} from "../service/IProductService.sol";
|
16
|
-
import {IPoolService} from "../service/IPoolService.sol";
|
17
|
-
|
18
|
-
import {IKeyValueStore} from "./IKeyValueStore.sol";
|
19
|
-
import {IInstance} from "../IInstance.sol";
|
20
|
-
import {IInstanceBase} from "./IInstanceBase.sol";
|
21
|
-
|
22
|
-
import {KeyValueStore} from "./KeyValueStore.sol";
|
23
|
-
|
24
|
-
abstract contract InstanceBase is
|
25
|
-
Versionable,
|
26
|
-
Registerable,
|
27
|
-
IInstanceBase
|
28
|
-
{
|
29
|
-
IKeyValueStore internal _keyValueStore;
|
30
|
-
|
31
|
-
IComponentOwnerService internal _componentOwnerService;
|
32
|
-
IDistributionService internal _distributionService;
|
33
|
-
IProductService internal _productService;
|
34
|
-
IPoolService internal _poolService;
|
35
|
-
|
36
|
-
constructor(
|
37
|
-
address registry,
|
38
|
-
NftId registryNftId
|
39
|
-
)
|
40
|
-
Registerable(registry, registryNftId)
|
41
|
-
Versionable()
|
42
|
-
{
|
43
|
-
_keyValueStore = new KeyValueStore();
|
44
|
-
|
45
|
-
_registerInterface(type(IInstance).interfaceId);
|
46
|
-
_linkToServicesInRegistry();
|
47
|
-
}
|
48
|
-
|
49
|
-
function getKeyValueStore() public view virtual override returns (IKeyValueStore keyValueStore) { return _keyValueStore; }
|
50
|
-
|
51
|
-
function updateState(Key32 key, StateId state) external override {
|
52
|
-
_keyValueStore.updateState(key, state);
|
53
|
-
}
|
54
|
-
|
55
|
-
function getState(Key32 key) external view override returns (StateId state) {
|
56
|
-
return _keyValueStore.getState(key);
|
57
|
-
}
|
58
|
-
|
59
|
-
// from versionable
|
60
|
-
function getVersion()
|
61
|
-
public
|
62
|
-
pure
|
63
|
-
virtual override
|
64
|
-
returns(Version)
|
65
|
-
{
|
66
|
-
return VersionLib.toVersion(3,0,0);
|
67
|
-
}
|
68
|
-
|
69
|
-
// from registerable
|
70
|
-
function getType() external pure override returns (ObjectType objectType) {
|
71
|
-
return INSTANCE();
|
72
|
-
}
|
73
|
-
|
74
|
-
|
75
|
-
// internal / private functions
|
76
|
-
function _linkToServicesInRegistry() internal {
|
77
|
-
VersionPart majorVersion = getVersion().toMajorPart();
|
78
|
-
_componentOwnerService = IComponentOwnerService(_getAndCheck("ComponentOwnerService", majorVersion));
|
79
|
-
_distributionService = IDistributionService(_getAndCheck("DistributionService", majorVersion));
|
80
|
-
_productService = IProductService(_getAndCheck("ProductService", majorVersion));
|
81
|
-
_poolService = IPoolService(_getAndCheck("PoolService", majorVersion));
|
82
|
-
}
|
83
|
-
|
84
|
-
function _getAndCheck(string memory serviceName, VersionPart majorVersion) internal view returns (address serviceAddress) {
|
85
|
-
serviceAddress = _registry.getServiceAddress(serviceName, majorVersion);
|
86
|
-
require(
|
87
|
-
serviceAddress != address(0),
|
88
|
-
"ERROR:INS-001:NOT_REGISTERED"
|
89
|
-
);
|
90
|
-
}
|
91
|
-
}
|
@@ -1,57 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
-
|
6
|
-
import {Blocknumber, blockNumber} from "../../types/Blocknumber.sol";
|
7
|
-
import {Key32, KeyId} from "../../types/Key32.sol";
|
8
|
-
import {LibNftIdSet} from "../../types/NftIdSet.sol";
|
9
|
-
import {NftId} from "../../types/NftId.sol";
|
10
|
-
import {ObjectType, PRODUCT, ORACLE, POOL, BUNDLE, POLICY} from "../../types/ObjectType.sol";
|
11
|
-
import {StateId, ACTIVE, PAUSED, ARCHIVED, CLOSED, APPLIED, REVOKED, DECLINED} from "../../types/StateId.sol";
|
12
|
-
import {Timestamp, blockTimestamp, zeroTimestamp} from "../../types/Timestamp.sol";
|
13
|
-
|
14
|
-
import {IKeyValueStore} from "./IKeyValueStore.sol";
|
15
|
-
|
16
|
-
abstract contract ModuleBase {
|
17
|
-
|
18
|
-
IKeyValueStore private _store;
|
19
|
-
|
20
|
-
function _initialize(IKeyValueStore keyValueStore) internal {
|
21
|
-
_store = keyValueStore;
|
22
|
-
}
|
23
|
-
|
24
|
-
function _create(ObjectType objectType, Key32 key, bytes memory data) internal {
|
25
|
-
_store.create(
|
26
|
-
key,
|
27
|
-
objectType,
|
28
|
-
data);
|
29
|
-
}
|
30
|
-
|
31
|
-
function _create(ObjectType objectType, NftId nftId, bytes memory data) internal {
|
32
|
-
_store.create(
|
33
|
-
nftId.toKey32(objectType),
|
34
|
-
objectType,
|
35
|
-
data);
|
36
|
-
}
|
37
|
-
|
38
|
-
function _updateData(ObjectType objectType, NftId nftId, bytes memory data) internal {
|
39
|
-
_store.updateData(nftId.toKey32(objectType), data);
|
40
|
-
}
|
41
|
-
|
42
|
-
function _updateState(ObjectType objectType, NftId nftId, StateId state) internal {
|
43
|
-
_store.updateState(nftId.toKey32(objectType), state);
|
44
|
-
}
|
45
|
-
|
46
|
-
function _exists(ObjectType objectType, NftId nftId) internal view returns (bool hasData) {
|
47
|
-
return _store.exists(nftId.toKey32(objectType));
|
48
|
-
}
|
49
|
-
|
50
|
-
function _getData(ObjectType objectType, NftId nftId) internal view returns(bytes memory data) {
|
51
|
-
return _store.getData(nftId.toKey32(objectType));
|
52
|
-
}
|
53
|
-
|
54
|
-
function _getState(ObjectType objectType, NftId nftId) internal view returns(StateId) {
|
55
|
-
return _store.getState(nftId.toKey32(objectType));
|
56
|
-
}
|
57
|
-
}
|
@@ -1,149 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
// role admin handling of oz doesn't fit nft ownability
|
5
|
-
// import {AccessControlEnumerable} from "@openzeppelin/contracts/access/AccessControlEnumerable.sol";
|
6
|
-
import "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
|
7
|
-
|
8
|
-
import {RoleId, RoleIdLib} from "../../../types/RoleId.sol";
|
9
|
-
import {DISTRIBUTION_OWNER_ROLE, ORACLE_OWNER_ROLE, POOL_OWNER_ROLE, PRODUCT_OWNER_ROLE} from "../../../types/RoleId.sol";
|
10
|
-
import {DISTRIBUTION_OWNER_ROLE_NAME, ORACLE_OWNER_ROLE_NAME, POOL_OWNER_ROLE_NAME, PRODUCT_OWNER_ROLE_NAME} from "../../../types/RoleId.sol";
|
11
|
-
import {IAccessModule} from "./IAccess.sol";
|
12
|
-
|
13
|
-
abstract contract AccessModule is IAccessModule {
|
14
|
-
|
15
|
-
using EnumerableSet for EnumerableSet.AddressSet;
|
16
|
-
|
17
|
-
mapping(RoleId role => RoleInfo info) private _info;
|
18
|
-
RoleId[] private _roles;
|
19
|
-
|
20
|
-
mapping(RoleId role => mapping(address member => bool isMember))
|
21
|
-
private _isRoleMember;
|
22
|
-
mapping(RoleId role => EnumerableSet.AddressSet members) private _roleMembers;
|
23
|
-
|
24
|
-
modifier onlyAccessOwner() {
|
25
|
-
require(
|
26
|
-
msg.sender == this.getOwner(),
|
27
|
-
"ERROR:ACS-001:NOT_OWNER");
|
28
|
-
_;
|
29
|
-
}
|
30
|
-
|
31
|
-
modifier onlyExistingRole(RoleId role) {
|
32
|
-
require(
|
33
|
-
_info[role].id == role,
|
34
|
-
"ERROR:ACS-002:ROLE_NOT_EXISTING");
|
35
|
-
_;
|
36
|
-
}
|
37
|
-
|
38
|
-
constructor() {
|
39
|
-
_createRole(DISTRIBUTION_OWNER_ROLE(), DISTRIBUTION_OWNER_ROLE_NAME());
|
40
|
-
_createRole(ORACLE_OWNER_ROLE(), ORACLE_OWNER_ROLE_NAME());
|
41
|
-
_createRole(POOL_OWNER_ROLE(), POOL_OWNER_ROLE_NAME());
|
42
|
-
_createRole(PRODUCT_OWNER_ROLE(), PRODUCT_OWNER_ROLE_NAME());
|
43
|
-
}
|
44
|
-
|
45
|
-
function createRole(
|
46
|
-
string memory roleName
|
47
|
-
) public override onlyAccessOwner returns (RoleId role) {
|
48
|
-
role = RoleIdLib.toRoleId(roleName);
|
49
|
-
require(
|
50
|
-
!roleExists(role),
|
51
|
-
"ERROR:ACS-010:ROLE_ALREADY_EXISTS");
|
52
|
-
|
53
|
-
_createRole(role, roleName);
|
54
|
-
}
|
55
|
-
|
56
|
-
function setRoleState(RoleId role, bool active) external override onlyExistingRole(role) onlyAccessOwner {
|
57
|
-
RoleInfo memory info = _info[role];
|
58
|
-
info.isActive = active;
|
59
|
-
_setRoleInfo(info);
|
60
|
-
|
61
|
-
emit LogAccessRoleStateSet(role, active);
|
62
|
-
}
|
63
|
-
|
64
|
-
function grantRole(
|
65
|
-
RoleId role,
|
66
|
-
address member
|
67
|
-
) external override onlyExistingRole(role) onlyAccessOwner {
|
68
|
-
require(_info[role].isActive, "ERROR:ACS-040:ROLE_NOT_ACTIVE");
|
69
|
-
|
70
|
-
_isRoleMember[role][member] = true;
|
71
|
-
_roleMembers[role].add(member);
|
72
|
-
|
73
|
-
emit LogAccessRoleGranted(role, member, _isRoleMember[role][member]);
|
74
|
-
}
|
75
|
-
|
76
|
-
function revokeRole(
|
77
|
-
RoleId role,
|
78
|
-
address member
|
79
|
-
) external override onlyExistingRole(role) onlyAccessOwner {
|
80
|
-
delete _isRoleMember[role][member];
|
81
|
-
_roleMembers[role].remove(member);
|
82
|
-
|
83
|
-
emit LogAccessRoleGranted(role, member, false);
|
84
|
-
}
|
85
|
-
|
86
|
-
function roleExists(RoleId role) public view virtual override returns (bool) {
|
87
|
-
return _info[role].id == role;
|
88
|
-
}
|
89
|
-
|
90
|
-
function hasRole(
|
91
|
-
RoleId role,
|
92
|
-
address member
|
93
|
-
) public view virtual override returns (bool) {
|
94
|
-
return _isRoleMember[role][member];
|
95
|
-
}
|
96
|
-
|
97
|
-
function getRoleId(string memory roleName) external pure override returns (RoleId role) {
|
98
|
-
return RoleIdLib.toRoleId(roleName);
|
99
|
-
}
|
100
|
-
|
101
|
-
function getRoleInfo(
|
102
|
-
RoleId role
|
103
|
-
) external view override returns (RoleInfo memory info) {
|
104
|
-
return _info[role];
|
105
|
-
}
|
106
|
-
|
107
|
-
function getRole(
|
108
|
-
uint256 idx
|
109
|
-
) external view override returns (RoleId role) {
|
110
|
-
return _roles[idx];
|
111
|
-
}
|
112
|
-
|
113
|
-
function getRoleCount() external view override returns (uint256 roles) {
|
114
|
-
return _roles.length;
|
115
|
-
}
|
116
|
-
|
117
|
-
function getRoleMemberCount(
|
118
|
-
RoleId role
|
119
|
-
) public view override returns (uint256 roleMembers) {
|
120
|
-
return _roleMembers[role].length();
|
121
|
-
}
|
122
|
-
|
123
|
-
function getRoleMember(
|
124
|
-
RoleId role,
|
125
|
-
uint256 idx
|
126
|
-
) public view override returns (address roleMembers) {
|
127
|
-
return _roleMembers[role].at(idx);
|
128
|
-
}
|
129
|
-
|
130
|
-
function _createRole(
|
131
|
-
RoleId role,
|
132
|
-
string memory roleName
|
133
|
-
) internal {
|
134
|
-
RoleInfo memory info = RoleInfo(role, roleName, true);
|
135
|
-
_setRoleInfo(info);
|
136
|
-
|
137
|
-
emit LogAccessRoleCreated(role, roleName);
|
138
|
-
}
|
139
|
-
|
140
|
-
function _setRoleInfo(
|
141
|
-
RoleInfo memory info
|
142
|
-
) internal {
|
143
|
-
RoleId role = info.id;
|
144
|
-
_info[role] = info;
|
145
|
-
if(!roleExists(role)) {
|
146
|
-
_roles.push(role);
|
147
|
-
}
|
148
|
-
}
|
149
|
-
}
|
@@ -1,53 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {RoleId} from "../../../types/RoleId.sol";
|
5
|
-
|
6
|
-
interface IAccess {
|
7
|
-
struct RoleInfo {
|
8
|
-
RoleId id;
|
9
|
-
string name;
|
10
|
-
bool isActive;
|
11
|
-
}
|
12
|
-
}
|
13
|
-
|
14
|
-
interface IAccessModule is
|
15
|
-
IAccess
|
16
|
-
{
|
17
|
-
event LogAccessRoleCreated(RoleId role, string roleName);
|
18
|
-
event LogAccessRoleStateSet(RoleId role, bool active);
|
19
|
-
event LogAccessRoleGranted(RoleId role, address member, bool isMember);
|
20
|
-
|
21
|
-
function createRole(string memory roleName) external returns (RoleId role);
|
22
|
-
|
23
|
-
function setRoleState(RoleId role, bool active) external;
|
24
|
-
|
25
|
-
function grantRole(RoleId role, address member) external;
|
26
|
-
|
27
|
-
function revokeRole(RoleId role, address member) external;
|
28
|
-
|
29
|
-
function roleExists(RoleId role) external view returns (bool);
|
30
|
-
|
31
|
-
function hasRole(RoleId role, address member) external view returns (bool);
|
32
|
-
|
33
|
-
function getRoleCount() external view returns (uint256 roles);
|
34
|
-
|
35
|
-
function getRole(uint256 idx) external view returns (RoleId role);
|
36
|
-
|
37
|
-
function getRoleId(string memory roleName) external pure returns (RoleId role);
|
38
|
-
|
39
|
-
function getRoleInfo(
|
40
|
-
RoleId role
|
41
|
-
) external view returns (RoleInfo memory info);
|
42
|
-
|
43
|
-
function getRoleMemberCount(
|
44
|
-
RoleId role
|
45
|
-
) external view returns (uint256 roleMembers);
|
46
|
-
|
47
|
-
function getRoleMember(
|
48
|
-
RoleId role,
|
49
|
-
uint256 idx
|
50
|
-
) external view returns (address roleMember);
|
51
|
-
|
52
|
-
function getOwner() external view returns (address owner);
|
53
|
-
}
|