@etherisc/gif-next 0.0.2-cc253b3 → 0.0.2-cddad6b-504
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 +178 -6
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{Component.sol/Component.json → BaseComponent.sol/BaseComponent.json} +48 -53
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +405 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{IPool.sol/IPoolComponent.json → IBaseComponent.sol/IBaseComponent.json} +48 -53
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +340 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +487 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +370 -0
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +405 -40
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +258 -45
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
- 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 +4 -0
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +59 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +74 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +207 -0
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +2 -2
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1362 -247
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol → IInstanceLinked.sol}/IInstanceLinked.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +1682 -356
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponentModule.json → base/ComponentServiceBase.sol/ComponentServiceBase.json} +156 -101
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +113 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +560 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.json +115 -0
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponentContract.json → base/IService.sol/IService.json} +148 -27
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.json +376 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +710 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +169 -0
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.json +10 -0
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +4 -0
- package/artifacts/contracts/{components/IProduct.sol/IProductComponent.json → instance/base/ServiceBase.sol/ServiceBase.json} +145 -37
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/Access.sol/AccessModule.json +85 -152
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/IAccess.sol/IAccess.json +1 -1
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/IAccess.sol/IAccessModule.json +96 -99
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +297 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.json +10 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +297 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +117 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/instance/{component → module/component}/IComponent.sol/IComponent.json +1 -1
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{product/IProductService.sol/IProductService.json → module/component/IComponent.sol/IComponentModule.json} +56 -53
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/distribution/DistributionModule.sol/DistributionModule.json +10 -0
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistribution.json +10 -0
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/distribution/IDistribution.sol/IDistributionModule.json +10 -0
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/IPolicy.sol/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/IPolicy.sol/IPolicyModule.json +159 -106
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/PolicyModule.sol/PolicyModule.json +159 -106
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool → module/pool}/IPoolModule.sol/IPool.json +1 -1
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool → module/pool}/IPoolModule.sol/IPoolModule.json +57 -62
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +144 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.json +10 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +113 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +131 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.json +10 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +511 -0
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +76 -0
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +511 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +531 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +420 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +364 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/ComponentModule.sol/ComponentModule.json → service/IDistributionService.sol/IDistributionService.json} +137 -139
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +440 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +630 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +543 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +858 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +65 -2
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +103 -77
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +24 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +194 -69
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryUpgradeable.sol/RegistryUpgradeable.json +495 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +35 -0
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IOwnable.sol}/IOwnable.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IRegisterable.sol}/IRegisterable.json +18 -63
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +164 -0
- package/artifacts/contracts/shared/Proxy.sol/Proxy.dbg.json +4 -0
- package/artifacts/contracts/shared/Proxy.sol/Proxy.json +178 -0
- package/artifacts/contracts/shared/Proxy.sol/ProxyWithProxyAdminGetter.dbg.json +4 -0
- package/artifacts/contracts/shared/Proxy.sol/ProxyWithProxyAdminGetter.json +129 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/{registry/Registry.sol → shared/Registerable.sol}/Registerable.json +18 -63
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/{instance/pool/PoolModule.sol/PoolModule.json → shared/Versionable.sol/Versionable.json} +74 -72
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.dbg.json +4 -0
- package/artifacts/contracts/shared/VersionableUpgradeable.sol/VersionableUpgradeable.json +187 -0
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.dbg.json +4 -0
- package/artifacts/contracts/test/TestDistribution.sol/TestDistribution.json +405 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +4 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +119 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +4 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +578 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +4 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +575 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +4 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +137 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +4 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +116 -0
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +4 -0
- package/artifacts/contracts/test/TestService.sol/TestService.json +379 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +4 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +338 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +218 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +206 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +4 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.json +338 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +10 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +174 -0
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +257 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +111 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +91 -6
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +10 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +92 -0
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ReferralId.sol/ReferralIdLib.json +99 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +86 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +30 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +92 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +236 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +479 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.json +139 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +30 -0
- package/contracts/components/BaseComponent.sol +94 -0
- package/contracts/components/Distribution.sol +132 -0
- package/contracts/components/IBaseComponent.sol +19 -0
- package/contracts/components/IDistributionComponent.sol +47 -0
- package/contracts/components/IPoolComponent.sol +71 -0
- package/contracts/components/IProductComponent.sol +38 -0
- package/contracts/components/Pool.sol +222 -16
- package/contracts/components/Product.sol +193 -32
- package/contracts/experiment/errors/Require.sol +10 -5
- package/contracts/experiment/errors/Revert.sol +13 -8
- package/contracts/experiment/inheritance/A.sol +8 -11
- package/contracts/experiment/inheritance/B.sol +10 -5
- package/contracts/experiment/inheritance/C.sol +11 -5
- package/contracts/experiment/inheritance/IA.sol +2 -7
- package/contracts/experiment/inheritance/IB.sol +3 -2
- package/contracts/experiment/inheritance/IC.sol +4 -3
- package/contracts/experiment/statemachine/Dummy.sol +27 -0
- package/contracts/experiment/statemachine/ISM.sol +25 -0
- package/contracts/experiment/statemachine/README.md +112 -0
- package/contracts/experiment/statemachine/SM.sol +57 -0
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +31 -0
- package/contracts/experiment/types/TypeA.sol +14 -9
- package/contracts/experiment/types/TypeB.sol +14 -9
- package/contracts/instance/IInstance.sol +41 -8
- package/contracts/instance/IInstanceLinked.sol +8 -0
- package/contracts/instance/Instance.sol +54 -44
- package/contracts/instance/base/ComponentServiceBase.sol +42 -0
- package/contracts/instance/base/IInstanceBase.sol +22 -0
- package/contracts/instance/base/IKeyValueStore.sol +50 -0
- package/contracts/instance/base/ILifecycle.sol +30 -0
- package/contracts/instance/base/IService.sol +15 -0
- package/contracts/instance/base/InstanceBase.sol +91 -0
- package/contracts/instance/base/KeyValueStore.sol +161 -0
- package/contracts/instance/base/Lifecycle.sol +100 -0
- package/contracts/instance/base/ModuleBase.sol +57 -0
- package/contracts/instance/base/ServiceBase.sol +37 -0
- package/contracts/instance/module/access/Access.sol +149 -0
- package/contracts/instance/module/access/IAccess.sol +53 -0
- package/contracts/instance/module/bundle/BundleModule.sol +134 -0
- package/contracts/instance/module/bundle/IBundle.sol +53 -0
- package/contracts/instance/module/component/ComponentModule.sol +70 -0
- package/contracts/instance/module/component/IComponent.sol +28 -0
- package/contracts/instance/module/distribution/DistributionModule.sol +17 -0
- package/contracts/instance/module/distribution/IDistribution.sol +10 -0
- package/contracts/instance/module/policy/IPolicy.sol +63 -0
- package/contracts/instance/module/policy/PolicyModule.sol +91 -0
- package/contracts/instance/module/pool/IPoolModule.sol +40 -0
- package/contracts/instance/module/pool/PoolModule.sol +90 -0
- package/contracts/instance/module/risk/IRisk.sol +26 -0
- package/contracts/instance/module/risk/RiskModule.sol +62 -0
- package/contracts/instance/module/treasury/ITreasury.sol +82 -0
- package/contracts/instance/module/treasury/TokenHandler.sol +48 -0
- package/contracts/instance/module/treasury/TreasuryModule.sol +138 -0
- package/contracts/instance/service/ComponentOwnerService.sol +157 -0
- package/contracts/instance/service/DistributionService.sol +59 -0
- package/contracts/instance/service/IComponentOwnerService.sol +22 -0
- package/contracts/instance/service/IDistributionService.sol +12 -0
- package/contracts/instance/service/IPoolService.sol +37 -0
- package/contracts/instance/service/IProductService.sol +107 -0
- package/contracts/instance/service/PoolService.sol +149 -0
- package/contracts/instance/service/ProductService.sol +509 -0
- package/contracts/registry/ChainNft.sol +80 -94
- package/contracts/registry/IChainNft.sol +10 -7
- package/contracts/registry/IRegistry.sol +38 -51
- package/contracts/registry/IRegistryLinked.sol +8 -0
- package/contracts/registry/Registry.sol +310 -111
- package/contracts/registry/RegistryUpgradeable.sol +416 -0
- package/contracts/shared/ERC165.sol +21 -0
- package/contracts/shared/IOwnable.sol +6 -0
- package/contracts/shared/IRegisterable.sol +24 -0
- package/contracts/shared/IVersionable.sol +52 -0
- package/contracts/shared/Proxy.sol +83 -0
- package/contracts/shared/Registerable.sol +86 -0
- package/contracts/shared/Versionable.sol +89 -0
- package/contracts/shared/VersionableUpgradeable.sol +108 -0
- package/contracts/test/TestDistribution.sol +21 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestPool.sol +25 -0
- package/contracts/test/TestProduct.sol +72 -0
- package/contracts/test/TestRegisterable.sol +19 -0
- package/contracts/test/TestRoleId.sol +14 -0
- package/contracts/test/TestService.sol +32 -0
- package/contracts/test/TestToken.sol +26 -0
- package/contracts/test/TestVersion.sol +44 -0
- package/contracts/test/TestVersionable.sol +17 -0
- package/contracts/test/Usdc.sol +26 -0
- package/contracts/types/AddressSet.sol +58 -0
- package/contracts/types/Blocknumber.sol +118 -0
- package/contracts/types/ChainId.sol +24 -10
- package/contracts/types/Fee.sol +56 -0
- package/contracts/types/Key32.sol +45 -0
- package/contracts/types/NftId.sol +55 -9
- package/contracts/types/NftIdSet.sol +60 -0
- package/contracts/types/ObjectType.sol +131 -0
- package/contracts/types/ReferralId.sol +48 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +38 -0
- package/contracts/types/StateId.sol +101 -0
- package/contracts/types/Timestamp.sol +123 -0
- package/contracts/types/UFixed.sol +209 -0
- package/contracts/types/Version.sol +95 -0
- package/package.json +19 -5
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +0 -35
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.json +0 -35
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.json +0 -50
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +0 -147
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +0 -94
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.json +0 -75
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.json +0 -75
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -167
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.json +0 -49
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +0 -60
- package/contracts/components/Component.sol +0 -62
- package/contracts/components/IPool.sol +0 -9
- package/contracts/components/IProduct.sol +0 -12
- package/contracts/instance/access/Access.sol +0 -218
- package/contracts/instance/access/IAccess.sol +0 -83
- package/contracts/instance/component/ComponentModule.sol +0 -248
- package/contracts/instance/component/IComponent.sol +0 -95
- package/contracts/instance/policy/IPolicy.sol +0 -66
- package/contracts/instance/policy/PolicyModule.sol +0 -107
- package/contracts/instance/pool/IPoolModule.sol +0 -41
- package/contracts/instance/pool/PoolModule.sol +0 -86
- package/contracts/instance/product/IProductService.sol +0 -46
- package/contracts/instance/product/ProductService.sol +0 -108
@@ -0,0 +1,416 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Initializable} from "@openzeppelin5/contracts/proxy/utils/Initializable.sol";
|
5
|
+
|
6
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
7
|
+
import {IService} from "../instance/base/IService.sol";
|
8
|
+
|
9
|
+
import {IChainNft} from "./IChainNft.sol";
|
10
|
+
import {ChainNft} from "./ChainNft.sol";
|
11
|
+
import {IRegistry} from "./IRegistry.sol";
|
12
|
+
import {NftId, toNftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
|
13
|
+
import {VersionPart} from "../types/Version.sol";
|
14
|
+
import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
|
15
|
+
|
16
|
+
// TODO make registry upgradable
|
17
|
+
contract RegistryUpgradeable is
|
18
|
+
Initializable,
|
19
|
+
IRegisterable,
|
20
|
+
IRegistry
|
21
|
+
{
|
22
|
+
using NftIdLib for NftId;
|
23
|
+
|
24
|
+
string public constant EMPTY_URI = "";
|
25
|
+
|
26
|
+
// @custom:storage-location erc7201:etherisc.storage.Registry
|
27
|
+
struct RegistryStorageV1 {// TODO encode version? at least just apropriate naming
|
28
|
+
|
29
|
+
mapping(NftId nftId => ObjectInfo info) _info;
|
30
|
+
mapping(address object => NftId nftId) _nftIdByAddress;
|
31
|
+
mapping(ObjectType objectType => bool) _isValidType;
|
32
|
+
mapping(ObjectType objectType => mapping(ObjectType objectParentType => bool)) _isValidParentType;
|
33
|
+
|
34
|
+
mapping(NftId nftId => string stringValue) _string;
|
35
|
+
mapping(bytes32 serviceNameHash => mapping(VersionPart majorVersion => address service)) _service;
|
36
|
+
|
37
|
+
NftId _nftId;
|
38
|
+
IChainNft _chainNft;
|
39
|
+
ChainNft _chainNftInternal;
|
40
|
+
address _initialOwner;
|
41
|
+
|
42
|
+
/// @dev will own protocol nft and registry nft(s) minted during initialize
|
43
|
+
address _protocolOwner;
|
44
|
+
}
|
45
|
+
|
46
|
+
// keccak256(abi.encode(uint256(keccak256("etherisc.storage.Registry")) - 1)) & ~bytes32(uint256(0xff));
|
47
|
+
bytes32 private constant RegistryStorageLocation = 0x6548007c3f4340f82f348c576c0ff69f4f529cadd5ad41f96aae61abceeaa300;
|
48
|
+
|
49
|
+
function _getRegistryStorageV1() private pure returns (RegistryStorageV1 storage $) {
|
50
|
+
assembly {
|
51
|
+
$.slot := RegistryStorageLocation
|
52
|
+
}
|
53
|
+
}
|
54
|
+
|
55
|
+
// TODO refactor once registry becomes upgradable
|
56
|
+
// @Dev the protocol owner will get ownership of the
|
57
|
+
// protocol nft and the global registry nft minted in this
|
58
|
+
// initializer function
|
59
|
+
function initialize(
|
60
|
+
address chainNft,
|
61
|
+
address protocolOwner
|
62
|
+
)
|
63
|
+
public
|
64
|
+
initializer
|
65
|
+
{
|
66
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
67
|
+
|
68
|
+
require(
|
69
|
+
address($._chainNft) == address(0),
|
70
|
+
"ERROR:REG-001:ALREADY_INITIALIZED"
|
71
|
+
);
|
72
|
+
|
73
|
+
$._initialOwner = msg.sender;
|
74
|
+
$._protocolOwner = protocolOwner;
|
75
|
+
|
76
|
+
$._chainNft = IChainNft(chainNft);
|
77
|
+
$._chainNftInternal = ChainNft(chainNft);
|
78
|
+
|
79
|
+
// initial registry setup
|
80
|
+
_registerProtocol();
|
81
|
+
$._nftId = _registerRegistry();
|
82
|
+
|
83
|
+
// setup rules for further registrations
|
84
|
+
_setupValidTypes();
|
85
|
+
_setupValidParentTypes();
|
86
|
+
}
|
87
|
+
|
88
|
+
|
89
|
+
function register(
|
90
|
+
address objectAddress
|
91
|
+
)
|
92
|
+
// TODO add authz (only services may register components etc)
|
93
|
+
// we have to check how we do authz for registring services (just restrict to protocol owner/registry owner)
|
94
|
+
external override returns (NftId nftId) {
|
95
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
96
|
+
|
97
|
+
require(
|
98
|
+
$._nftIdByAddress[objectAddress].eqz(),
|
99
|
+
"ERROR:REG-002:ALREADY_REGISTERED"
|
100
|
+
);
|
101
|
+
|
102
|
+
IRegisterable registerable = IRegisterable(objectAddress);
|
103
|
+
require(
|
104
|
+
registerable.supportsInterface(type(IRegisterable).interfaceId),
|
105
|
+
"ERROR:REG-003:NOT_REGISTERABLE"
|
106
|
+
);
|
107
|
+
|
108
|
+
ObjectType objectType = registerable.getType();
|
109
|
+
require(
|
110
|
+
$._isValidType[objectType],
|
111
|
+
"ERROR:REG-004:TYPE_INVALID"
|
112
|
+
);
|
113
|
+
|
114
|
+
NftId parentNftId = registerable.getParentNftId();
|
115
|
+
require(
|
116
|
+
isRegistered(parentNftId),
|
117
|
+
"ERROR:REG-005:PARENT_NOT_REGISTERED"
|
118
|
+
);
|
119
|
+
|
120
|
+
require(
|
121
|
+
$._isValidParentType[objectType][$._info[parentNftId].objectType],
|
122
|
+
"ERROR:REG-006:PARENT_TYPE_INVALID"
|
123
|
+
);
|
124
|
+
|
125
|
+
// also check that nftId and parentNFtId are on the same chain if applicable
|
126
|
+
|
127
|
+
// nft minting
|
128
|
+
uint256 mintedTokenId = $._chainNft.mint(
|
129
|
+
registerable.getOwner(),
|
130
|
+
EMPTY_URI
|
131
|
+
);
|
132
|
+
|
133
|
+
nftId = toNftId(mintedTokenId);
|
134
|
+
|
135
|
+
// special case services
|
136
|
+
if(registerable.getType() == SERVICE()) {
|
137
|
+
IService service = IService(objectAddress);
|
138
|
+
require(
|
139
|
+
service.supportsInterface(type(IService).interfaceId),
|
140
|
+
"ERROR:REG-007:NOT_SERVICE"
|
141
|
+
);
|
142
|
+
|
143
|
+
string memory serviceName = service.getName();
|
144
|
+
VersionPart majorVersion = service.getMajorVersion();
|
145
|
+
bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
|
146
|
+
|
147
|
+
// service specific state
|
148
|
+
$._string[nftId] = serviceName;
|
149
|
+
|
150
|
+
require(
|
151
|
+
$._service[serviceNameHash][majorVersion] == address(0),
|
152
|
+
"ERROR:REG-008:ALREADY_REGISTERED"
|
153
|
+
);
|
154
|
+
$._service[serviceNameHash][majorVersion] = objectAddress;
|
155
|
+
}
|
156
|
+
|
157
|
+
// create object info and link nft id with it
|
158
|
+
_registerObjectInfo(registerable, nftId);
|
159
|
+
}
|
160
|
+
|
161
|
+
|
162
|
+
function registerObjectForInstance(
|
163
|
+
NftId parentNftId,
|
164
|
+
ObjectType objectType,
|
165
|
+
address initialOwner,
|
166
|
+
bytes memory data
|
167
|
+
)
|
168
|
+
external
|
169
|
+
override
|
170
|
+
returns (
|
171
|
+
// TODO add onlyRegisteredInstance
|
172
|
+
NftId nftId
|
173
|
+
)
|
174
|
+
{
|
175
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
176
|
+
|
177
|
+
// TODO add more validation
|
178
|
+
require(
|
179
|
+
objectType == POLICY() || objectType == BUNDLE(),
|
180
|
+
"ERROR:REG-010:TYPE_INVALID"
|
181
|
+
);
|
182
|
+
|
183
|
+
uint256 mintedTokenId = $._chainNft.mint(initialOwner, EMPTY_URI);
|
184
|
+
nftId = toNftId(mintedTokenId);
|
185
|
+
|
186
|
+
ObjectInfo memory info = ObjectInfo(
|
187
|
+
nftId,
|
188
|
+
parentNftId,
|
189
|
+
objectType,
|
190
|
+
address(0),
|
191
|
+
initialOwner,
|
192
|
+
data
|
193
|
+
);
|
194
|
+
|
195
|
+
$._info[nftId] = info;
|
196
|
+
|
197
|
+
// add logging
|
198
|
+
}
|
199
|
+
|
200
|
+
function getObjectCount() external view override returns (uint256) {
|
201
|
+
return _getRegistryStorageV1()._chainNft.totalSupply();
|
202
|
+
}
|
203
|
+
|
204
|
+
function getNftId(
|
205
|
+
address object
|
206
|
+
) external view override returns (NftId id) {
|
207
|
+
return _getRegistryStorageV1()._nftIdByAddress[object];
|
208
|
+
}
|
209
|
+
|
210
|
+
function isRegistered(
|
211
|
+
NftId nftId
|
212
|
+
) public view override returns (bool) {
|
213
|
+
return _getRegistryStorageV1()._info[nftId].objectType.gtz();
|
214
|
+
}
|
215
|
+
|
216
|
+
function isRegistered(
|
217
|
+
address object
|
218
|
+
) external view override returns (bool) {
|
219
|
+
return _getRegistryStorageV1()._nftIdByAddress[object].gtz();
|
220
|
+
}
|
221
|
+
|
222
|
+
function getObjectInfo(
|
223
|
+
NftId nftId
|
224
|
+
) external view override returns (ObjectInfo memory info) {
|
225
|
+
return _getRegistryStorageV1()._info[nftId];
|
226
|
+
}
|
227
|
+
|
228
|
+
function getName(
|
229
|
+
NftId nftId
|
230
|
+
) external view returns (string memory name) {
|
231
|
+
return _getRegistryStorageV1()._string[nftId];
|
232
|
+
}
|
233
|
+
|
234
|
+
function getOwner(NftId nftId) external view override returns (address) {
|
235
|
+
return _getRegistryStorageV1()._chainNft.ownerOf(nftId.toInt());
|
236
|
+
}
|
237
|
+
|
238
|
+
function getChainNft() external view override returns (IChainNft) {
|
239
|
+
return _getRegistryStorageV1()._chainNft;
|
240
|
+
}
|
241
|
+
|
242
|
+
// special case to retrive a gif service
|
243
|
+
function getServiceAddress(string memory serviceName, VersionPart majorVersion) external view override returns (address serviceAddress) {
|
244
|
+
bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
|
245
|
+
return _getRegistryStorageV1()._service[serviceNameHash][majorVersion];
|
246
|
+
}
|
247
|
+
|
248
|
+
// from IERC165
|
249
|
+
function supportsInterface(bytes4 interfaceId) external pure override returns (bool) {
|
250
|
+
return interfaceId == type(IRegistry).interfaceId;
|
251
|
+
}
|
252
|
+
|
253
|
+
// from IRegistryLinked
|
254
|
+
function getRegistry() external view override returns (IRegistry registry) {
|
255
|
+
return this;
|
256
|
+
}
|
257
|
+
|
258
|
+
// from IRegisterable
|
259
|
+
function register() external pure override returns (NftId nftId) {
|
260
|
+
return zeroNftId();
|
261
|
+
}
|
262
|
+
|
263
|
+
function getType() external pure override returns (ObjectType objectType) {
|
264
|
+
return REGISTRY();
|
265
|
+
}
|
266
|
+
|
267
|
+
|
268
|
+
function getOwner() public view override returns (address owner) {
|
269
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
270
|
+
return $._nftId.gtz() ? this.getOwner($._nftId) : $._initialOwner;
|
271
|
+
}
|
272
|
+
|
273
|
+
function getNftId() external view override (IRegisterable, IRegistry) returns (NftId nftId) {
|
274
|
+
return _getRegistryStorageV1()._nftId;
|
275
|
+
}
|
276
|
+
|
277
|
+
function getParentNftId() external view returns (NftId nftId) {
|
278
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
279
|
+
// we're the global registry
|
280
|
+
if(block.chainid == 1) {
|
281
|
+
return toNftId($._chainNftInternal.PROTOCOL_NFT_ID());
|
282
|
+
}
|
283
|
+
else {
|
284
|
+
return toNftId($._chainNftInternal.GLOBAL_REGISTRY_ID());
|
285
|
+
}
|
286
|
+
}
|
287
|
+
|
288
|
+
function getData() external pure returns (bytes memory data) {
|
289
|
+
return "";
|
290
|
+
}
|
291
|
+
|
292
|
+
// registry specific functions
|
293
|
+
function getProtocolOwner() external view override returns (address) {
|
294
|
+
return _getRegistryStorageV1()._protocolOwner;
|
295
|
+
}
|
296
|
+
|
297
|
+
/// @dev defines which types are allowed to register
|
298
|
+
function _setupValidTypes() internal {
|
299
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
300
|
+
$._isValidType[REGISTRY()] = true; // only for global registry
|
301
|
+
$._isValidType[TOKEN()] = true;
|
302
|
+
$._isValidType[SERVICE()] = true;
|
303
|
+
$._isValidType[INSTANCE()] = true;
|
304
|
+
$._isValidType[STAKE()] = true;
|
305
|
+
$._isValidType[PRODUCT()] = true;
|
306
|
+
$._isValidType[ORACLE()] = true;
|
307
|
+
$._isValidType[POOL()] = true;
|
308
|
+
$._isValidType[DISTRIBUTION()] = true;
|
309
|
+
$._isValidType[POLICY()] = true;
|
310
|
+
$._isValidType[BUNDLE()] = true;
|
311
|
+
}
|
312
|
+
|
313
|
+
/// @dev defines which types - parent type relations are allowed to register
|
314
|
+
function _setupValidParentTypes() internal {
|
315
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
316
|
+
// registry as parent
|
317
|
+
$._isValidParentType[TOKEN()][REGISTRY()] = true;
|
318
|
+
$._isValidParentType[SERVICE()][REGISTRY()] = true;
|
319
|
+
$._isValidParentType[INSTANCE()][REGISTRY()] = true;
|
320
|
+
|
321
|
+
// instance as parent
|
322
|
+
$._isValidParentType[PRODUCT()][INSTANCE()] = true;
|
323
|
+
$._isValidParentType[DISTRIBUTION()][INSTANCE()] = true;
|
324
|
+
$._isValidParentType[ORACLE()][INSTANCE()] = true;
|
325
|
+
$._isValidParentType[POOL()][INSTANCE()] = true;
|
326
|
+
|
327
|
+
// product as parent
|
328
|
+
$._isValidParentType[POLICY()][PRODUCT()] = true;
|
329
|
+
|
330
|
+
// pool as parent
|
331
|
+
$._isValidParentType[BUNDLE()][POOL()] = true;
|
332
|
+
$._isValidParentType[STAKE()][POOL()] = true;
|
333
|
+
}
|
334
|
+
|
335
|
+
/// @dev protocol registration used to anchor the dip ecosystem relations
|
336
|
+
function _registerProtocol() virtual internal {
|
337
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
338
|
+
|
339
|
+
uint256 protocolId = $._chainNftInternal.PROTOCOL_NFT_ID();
|
340
|
+
$._chainNftInternal.mint($._protocolOwner, protocolId);
|
341
|
+
|
342
|
+
NftId protocolNftid = toNftId(protocolId);
|
343
|
+
ObjectInfo memory protocolInfo = ObjectInfo(
|
344
|
+
protocolNftid,
|
345
|
+
zeroNftId(), // parent nft id
|
346
|
+
PROTOCOL(),
|
347
|
+
address(0), // contract address
|
348
|
+
$._protocolOwner,
|
349
|
+
"" // data
|
350
|
+
);
|
351
|
+
|
352
|
+
$._info[protocolNftid] = protocolInfo;
|
353
|
+
}
|
354
|
+
|
355
|
+
/// @dev registry registration
|
356
|
+
/// might also register the global registry when not on mainnet
|
357
|
+
function _registerRegistry() virtual internal returns (NftId registryNftId) {
|
358
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
359
|
+
|
360
|
+
uint256 registryId = $._chainNftInternal.calculateTokenId(2);
|
361
|
+
registryNftId = toNftId(registryId);
|
362
|
+
|
363
|
+
// we're not the global registry
|
364
|
+
if(registryId != $._chainNftInternal.GLOBAL_REGISTRY_ID()) {
|
365
|
+
_registerGlobalRegistry();
|
366
|
+
}
|
367
|
+
|
368
|
+
$._chainNftInternal.mint($._protocolOwner, registryId);
|
369
|
+
_registerObjectInfo(this, registryNftId);
|
370
|
+
}
|
371
|
+
|
372
|
+
|
373
|
+
/// @dev global registry registration for non mainnet registries
|
374
|
+
function _registerGlobalRegistry() virtual internal {
|
375
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
376
|
+
|
377
|
+
uint256 globalRegistryId = $._chainNftInternal.GLOBAL_REGISTRY_ID();
|
378
|
+
$._chainNftInternal.mint($._protocolOwner, globalRegistryId);
|
379
|
+
|
380
|
+
NftId globalRegistryNftId = toNftId(globalRegistryId);
|
381
|
+
ObjectInfo memory globalRegistryInfo = ObjectInfo(
|
382
|
+
globalRegistryNftId,
|
383
|
+
toNftId($._chainNftInternal.PROTOCOL_NFT_ID()),
|
384
|
+
REGISTRY(),
|
385
|
+
address(0), // contract address
|
386
|
+
$._protocolOwner,
|
387
|
+
"" // data
|
388
|
+
);
|
389
|
+
|
390
|
+
$._info[globalRegistryNftId] = globalRegistryInfo;
|
391
|
+
}
|
392
|
+
|
393
|
+
|
394
|
+
function _registerObjectInfo(
|
395
|
+
IRegisterable registerable,
|
396
|
+
NftId nftId
|
397
|
+
) internal virtual {
|
398
|
+
RegistryStorageV1 storage $ = _getRegistryStorageV1();
|
399
|
+
|
400
|
+
address objectAddress = address(registerable);
|
401
|
+
ObjectInfo memory info = ObjectInfo(
|
402
|
+
nftId,
|
403
|
+
registerable.getParentNftId(),
|
404
|
+
registerable.getType(),
|
405
|
+
objectAddress,
|
406
|
+
registerable.getOwner(),
|
407
|
+
registerable.getData()
|
408
|
+
);
|
409
|
+
|
410
|
+
$._info[nftId] = info;
|
411
|
+
$._nftIdByAddress[objectAddress] = nftId;
|
412
|
+
|
413
|
+
// add logging
|
414
|
+
}
|
415
|
+
|
416
|
+
}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
|
6
|
+
contract ERC165 is IERC165 {
|
7
|
+
mapping(bytes4 => bool) private _isSupported;
|
8
|
+
|
9
|
+
constructor() {
|
10
|
+
// register support for ERC165
|
11
|
+
_registerInterface(type(IERC165).interfaceId);
|
12
|
+
}
|
13
|
+
|
14
|
+
function supportsInterface(bytes4 interfaceId) external view override returns (bool) {
|
15
|
+
return _isSupported[interfaceId];
|
16
|
+
}
|
17
|
+
|
18
|
+
function _registerInterface(bytes4 interfaceId) internal {
|
19
|
+
_isSupported[interfaceId] = true;
|
20
|
+
}
|
21
|
+
}
|
@@ -0,0 +1,24 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
|
6
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
7
|
+
import {NftId} from "../types/NftId.sol";
|
8
|
+
import {ObjectType} from "../types/ObjectType.sol";
|
9
|
+
|
10
|
+
import {IOwnable} from "./IOwnable.sol";
|
11
|
+
|
12
|
+
interface IRegisterable is IERC165, IOwnable {
|
13
|
+
function getRegistry() external view returns (IRegistry registry);
|
14
|
+
|
15
|
+
function register() external returns (NftId nftId);
|
16
|
+
|
17
|
+
function getType() external pure returns (ObjectType objectType);
|
18
|
+
|
19
|
+
function getNftId() external view returns (NftId nftId);
|
20
|
+
|
21
|
+
function getParentNftId() external view returns (NftId nftId);
|
22
|
+
|
23
|
+
function getData() external view returns (bytes memory data);
|
24
|
+
}
|
@@ -0,0 +1,52 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {Blocknumber, blockNumber} from "../types/Blocknumber.sol";
|
5
|
+
import {Timestamp, blockTimestamp} from "../types/Timestamp.sol";
|
6
|
+
import {Version, VersionPart} from "../types/Version.sol";
|
7
|
+
|
8
|
+
interface IVersionable {
|
9
|
+
|
10
|
+
struct VersionInfo {
|
11
|
+
Version version;
|
12
|
+
address implementation;
|
13
|
+
address activatedBy;
|
14
|
+
Timestamp activatedAt;
|
15
|
+
Blocknumber activatedIn;
|
16
|
+
}
|
17
|
+
|
18
|
+
event LogVersionableActivated(Version version, address implementation, address activatedBy);
|
19
|
+
|
20
|
+
/**
|
21
|
+
* @dev IMPORTANT this function needs to be implemented by each new version
|
22
|
+
* any such activate implementation needs to call internal function call _activate()
|
23
|
+
* any new version needs to inherit from previous version
|
24
|
+
*/
|
25
|
+
function activate(address implementation, address activatedBy) external;
|
26
|
+
|
27
|
+
/**
|
28
|
+
* @dev returns true if the specified version has been activated for the current contract
|
29
|
+
*/
|
30
|
+
function isActivated(Version version) external view returns(bool);
|
31
|
+
|
32
|
+
/**
|
33
|
+
* @dev returns currently active version of this contract
|
34
|
+
*/
|
35
|
+
function getVersion() external pure returns(Version);
|
36
|
+
|
37
|
+
/**
|
38
|
+
* @dev returns the number of all deployed versions of this contract
|
39
|
+
*/
|
40
|
+
function getVersionCount() external view returns(uint256 numberOfVersions);
|
41
|
+
|
42
|
+
/**
|
43
|
+
* @dev returns the i-th (index) version of this contract
|
44
|
+
*/
|
45
|
+
function getVersion(uint256 index) external view returns(Version version);
|
46
|
+
|
47
|
+
/**
|
48
|
+
* @dev returns the i-th (index) version info of this contract
|
49
|
+
*/
|
50
|
+
function getVersionInfo(Version version) external view returns(VersionInfo memory versionInfo);
|
51
|
+
|
52
|
+
}
|
@@ -0,0 +1,83 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Ownable} from "@openzeppelin5/contracts/access/Ownable.sol";
|
5
|
+
import {ProxyAdmin} from "@openzeppelin5/contracts/proxy/transparent/ProxyAdmin.sol";
|
6
|
+
import {TransparentUpgradeableProxy, ITransparentUpgradeableProxy} from "@openzeppelin5/contracts/proxy/transparent/TransparentUpgradeableProxy.sol";
|
7
|
+
|
8
|
+
import {IVersionable} from "./IVersionable.sol";
|
9
|
+
|
10
|
+
contract ProxyWithProxyAdminGetter is TransparentUpgradeableProxy {
|
11
|
+
|
12
|
+
constructor(address implementation, address initialProxyAdminOwner,bytes memory data)
|
13
|
+
TransparentUpgradeableProxy(implementation, initialProxyAdminOwner, data)
|
14
|
+
{}
|
15
|
+
|
16
|
+
function getProxyAdmin() external returns (ProxyAdmin) { return ProxyAdmin(_proxyAdmin()); }
|
17
|
+
}
|
18
|
+
|
19
|
+
contract Proxy is Ownable {
|
20
|
+
|
21
|
+
string public constant ACTIVATE_SIGNATURE = "activate(address,address)";
|
22
|
+
|
23
|
+
ProxyWithProxyAdminGetter private _proxy;
|
24
|
+
bool private _isDeployed;
|
25
|
+
|
26
|
+
/// @dev only used to capture proxy owner
|
27
|
+
constructor()
|
28
|
+
Ownable(msg.sender)
|
29
|
+
{
|
30
|
+
}
|
31
|
+
|
32
|
+
function getData(address implementation, address proxyOwner) public pure returns (bytes memory data) {
|
33
|
+
return abi.encodeWithSignature(ACTIVATE_SIGNATURE, implementation, proxyOwner);
|
34
|
+
}
|
35
|
+
|
36
|
+
/// @dev deploy initial contract
|
37
|
+
function deploy(address initialImplementation)
|
38
|
+
external
|
39
|
+
onlyOwner()
|
40
|
+
returns (IVersionable versionable)
|
41
|
+
{
|
42
|
+
require(!_isDeployed, "ERROR:PRX-010:ALREADY_DEPLOYED");
|
43
|
+
|
44
|
+
address currentProxyOwner = owner();
|
45
|
+
address initialProxyAdminOwner = address(this);
|
46
|
+
bytes memory data = getData(initialImplementation, currentProxyOwner);
|
47
|
+
|
48
|
+
_proxy = new ProxyWithProxyAdminGetter(
|
49
|
+
initialImplementation,
|
50
|
+
initialProxyAdminOwner,
|
51
|
+
data
|
52
|
+
);
|
53
|
+
|
54
|
+
_isDeployed = true;
|
55
|
+
versionable = IVersionable(address(_proxy));
|
56
|
+
}
|
57
|
+
|
58
|
+
/// @dev upgrade existing contract
|
59
|
+
function upgrade(address newImplementation)
|
60
|
+
external
|
61
|
+
onlyOwner
|
62
|
+
returns (IVersionable versionable)
|
63
|
+
{
|
64
|
+
require(_isDeployed, "ERROR:PRX-020:NOT_YET_DEPLOYED");
|
65
|
+
|
66
|
+
address currentProxyOwner = owner();
|
67
|
+
// ProxyAdmin proxyAdmin = _proxy.getProxyAdmin();
|
68
|
+
ProxyAdmin proxyAdmin = getProxyAdmin();
|
69
|
+
ITransparentUpgradeableProxy proxy = ITransparentUpgradeableProxy(address(_proxy));
|
70
|
+
bytes memory data = getData(newImplementation, currentProxyOwner);
|
71
|
+
|
72
|
+
proxyAdmin.upgradeAndCall(
|
73
|
+
proxy,
|
74
|
+
newImplementation,
|
75
|
+
data);
|
76
|
+
|
77
|
+
versionable = IVersionable(address(_proxy));
|
78
|
+
}
|
79
|
+
|
80
|
+
function getProxyAdmin() public returns (ProxyAdmin) {
|
81
|
+
return _proxy.getProxyAdmin();
|
82
|
+
}
|
83
|
+
}
|
@@ -0,0 +1,86 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {NftId, zeroNftId} from "../types/NftId.sol";
|
5
|
+
import {ObjectType} from "../types/ObjectType.sol";
|
6
|
+
|
7
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
8
|
+
import {IRegisterable} from "./IRegisterable.sol";
|
9
|
+
|
10
|
+
import {ERC165} from "./ERC165.sol";
|
11
|
+
|
12
|
+
abstract contract Registerable is
|
13
|
+
ERC165,
|
14
|
+
IRegisterable
|
15
|
+
{
|
16
|
+
IRegistry internal immutable _registry;
|
17
|
+
NftId internal immutable _parentNftId;
|
18
|
+
address internal immutable _initialOwner;
|
19
|
+
|
20
|
+
modifier onlyOwner() virtual {
|
21
|
+
require(
|
22
|
+
msg.sender == getOwner(),
|
23
|
+
"ERROR:RGB-001:NOT_OWNER"
|
24
|
+
);
|
25
|
+
_;
|
26
|
+
}
|
27
|
+
|
28
|
+
constructor(
|
29
|
+
address registryAddress,
|
30
|
+
NftId parentNftId
|
31
|
+
)
|
32
|
+
ERC165()
|
33
|
+
{
|
34
|
+
require(
|
35
|
+
address(registryAddress) != address(0),
|
36
|
+
"ERROR:RGB-010:REGISTRY_ZERO"
|
37
|
+
);
|
38
|
+
|
39
|
+
_registry = IRegistry(registryAddress);
|
40
|
+
require(
|
41
|
+
_registry.supportsInterface(type(IRegistry).interfaceId),
|
42
|
+
"ERROR:RGB-011:NOT_REGISTRY"
|
43
|
+
);
|
44
|
+
|
45
|
+
_parentNftId = parentNftId;
|
46
|
+
require(
|
47
|
+
_registry.isRegistered(_parentNftId),
|
48
|
+
"ERROR:RGB-012:PARENT_NOT_REGISTERED"
|
49
|
+
);
|
50
|
+
|
51
|
+
_initialOwner = msg.sender;
|
52
|
+
|
53
|
+
// register support for IRegisterable
|
54
|
+
_registerInterface(type(IRegisterable).interfaceId);
|
55
|
+
}
|
56
|
+
|
57
|
+
// from IRegistryLinked
|
58
|
+
function register() public onlyOwner virtual override returns (NftId nftId) {
|
59
|
+
return _registry.register(address(this));
|
60
|
+
}
|
61
|
+
|
62
|
+
function getRegistry() public view virtual override returns (IRegistry registry) {
|
63
|
+
return _registry;
|
64
|
+
}
|
65
|
+
|
66
|
+
function getOwner() public view virtual override returns (address owner) {
|
67
|
+
NftId nftId = _registry.getNftId(address(this));
|
68
|
+
if(nftId == zeroNftId()) {
|
69
|
+
return _initialOwner;
|
70
|
+
}
|
71
|
+
|
72
|
+
return _registry.getOwner(nftId);
|
73
|
+
}
|
74
|
+
|
75
|
+
function getNftId() public view override returns (NftId nftId) {
|
76
|
+
return _registry.getNftId(address(this));
|
77
|
+
}
|
78
|
+
|
79
|
+
function getParentNftId() public view override returns (NftId nftId) {
|
80
|
+
return _parentNftId;
|
81
|
+
}
|
82
|
+
|
83
|
+
function getData() public view virtual override returns (bytes memory data) {
|
84
|
+
return "";
|
85
|
+
}
|
86
|
+
}
|