@etherisc/gif-next 0.0.2-f9905e1 → 0.0.2-f9bc4c7-556
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 +123 -7
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{IPool.sol/IPoolComponent.json → BaseComponent.sol/BaseComponent.json} +55 -60
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +4 -0
- package/artifacts/contracts/{instance/component/IComponent.sol/IComponentContract.json → components/IBaseComponent.sol/IBaseComponent.json} +54 -59
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +356 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +279 -0
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +225 -33
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +154 -62
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +105 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +105 -0
- 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 +1249 -275
- 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 +1560 -373
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +300 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/{product/ProductService.sol/ProductModule.json → base/IInstanceBase.sol/IInstanceBase.json} +18 -30
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +511 -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/base/IService.sol/IService.json +300 -0
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/ComponentModule.sol/ComponentModule.json → base/InstanceBase.sol/InstanceBase.json} +140 -141
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +692 -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/instance/base/ServiceBase.sol/ServiceBase.json +300 -0
- 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 +296 -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 +296 -0
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.json +10 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.json +10 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.json +10 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +188 -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/{component → module/component}/IComponent.sol/IComponentModule.json +54 -111
- 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 +146 -116
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/PolicyModule.sol/PolicyModule.json +146 -116
- 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 +63 -63
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +149 -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 +10 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +10 -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 +533 -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 +533 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +523 -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/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +376 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +477 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +471 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +673 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +597 -0
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +452 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +115 -81
- 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 +265 -82
- 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 +22 -67
- 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/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/{registry/Registry.sol → shared/Registerable.sol}/Registerable.json +23 -68
- 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} +72 -70
- 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 +387 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +4 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +393 -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 +218 -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 +4 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +153 -0
- 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/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 +88 -0
- package/contracts/components/IBaseComponent.sol +19 -0
- package/contracts/components/IPoolComponent.sol +57 -0
- package/contracts/components/IProductComponent.sol +19 -0
- package/contracts/components/Pool.sol +161 -16
- package/contracts/components/Product.sol +79 -27
- package/contracts/experiment/errors/Require.sol +38 -0
- package/contracts/experiment/errors/Revert.sol +44 -0
- 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 +42 -10
- package/contracts/instance/IInstanceLinked.sol +8 -0
- package/contracts/instance/Instance.sol +47 -42
- package/contracts/instance/base/ComponentServiceBase.sol +42 -0
- package/contracts/instance/base/IInstanceBase.sol +14 -0
- package/contracts/instance/base/IKeyValueStore.sol +49 -0
- package/contracts/instance/base/ILifecycle.sol +30 -0
- package/contracts/instance/base/IService.sol +15 -0
- package/contracts/instance/base/InstanceBase.sol +80 -0
- package/contracts/instance/base/KeyValueStore.sol +156 -0
- package/contracts/instance/base/Lifecycle.sol +95 -0
- package/contracts/instance/base/ModuleBase.sol +52 -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 +136 -0
- package/contracts/instance/module/bundle/IBundle.sol +58 -0
- package/contracts/instance/module/compensation/CompensationModule.sol +8 -0
- package/contracts/instance/module/compensation/ICompensation.sol +10 -0
- package/contracts/instance/module/component/ComponentModule.sol +95 -0
- package/contracts/instance/module/component/IComponent.sol +53 -0
- package/contracts/instance/module/policy/IPolicy.sol +60 -0
- package/contracts/instance/module/policy/PolicyModule.sol +76 -0
- package/contracts/instance/module/pool/IPoolModule.sol +41 -0
- package/contracts/instance/module/pool/PoolModule.sol +87 -0
- package/contracts/instance/module/risk/IRisk.sol +10 -0
- package/contracts/instance/module/risk/RiskModule.sol +8 -0
- package/contracts/instance/module/treasury/ITreasury.sol +103 -0
- package/contracts/instance/module/treasury/TokenHandler.sol +48 -0
- package/contracts/instance/module/treasury/TreasuryModule.sol +152 -0
- package/contracts/instance/service/ComponentOwnerService.sol +170 -0
- package/contracts/instance/service/IComponentOwnerService.sol +22 -0
- package/contracts/instance/service/IPoolService.sol +30 -0
- package/contracts/instance/service/IProductService.sol +58 -0
- package/contracts/instance/service/PoolService.sol +123 -0
- package/contracts/instance/service/ProductService.sol +354 -0
- package/contracts/registry/ChainNft.sol +159 -0
- package/contracts/registry/IChainNft.sol +21 -0
- package/contracts/registry/IRegistry.sol +41 -50
- package/contracts/registry/IRegistryLinked.sol +8 -0
- package/contracts/registry/Registry.sol +307 -123
- 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/Registerable.sol +86 -0
- package/contracts/shared/Versionable.sol +89 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestPool.sol +22 -0
- package/contracts/test/TestProduct.sol +44 -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 +51 -0
- package/contracts/types/Key32.sol +45 -0
- package/contracts/types/NftId.sol +72 -0
- package/contracts/types/NftIdSet.sol +60 -0
- package/contracts/types/ObjectType.sol +115 -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/Component.json +0 -179
- 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/components/IProduct.sol/IProductComponent.json +0 -192
- 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 -105
- 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/IProductService.sol/IProductService.json +0 -114
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -125
- 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 -11
- package/contracts/instance/access/Access.sol +0 -218
- package/contracts/instance/access/IAccess.sol +0 -83
- package/contracts/instance/component/ComponentModule.sol +0 -259
- package/contracts/instance/component/IComponent.sol +0 -94
- package/contracts/instance/policy/IPolicy.sol +0 -66
- package/contracts/instance/policy/PolicyModule.sol +0 -106
- package/contracts/instance/pool/IPoolModule.sol +0 -40
- package/contracts/instance/pool/PoolModule.sol +0 -83
- package/contracts/instance/product/IProductService.sol +0 -45
- package/contracts/instance/product/ProductService.sol +0 -105
@@ -1,66 +1,57 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
-
|
5
|
-
|
6
|
-
}
|
4
|
+
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
|
6
|
+
import {NftId} from "../types/NftId.sol";
|
7
|
+
import {ObjectType} from "../types/ObjectType.sol";
|
8
|
+
import {VersionPart} from "../types/Version.sol";
|
9
|
+
import {IChainNft} from "./IChainNft.sol";
|
10
|
+
|
11
|
+
interface IRegistry is IERC165 {
|
12
|
+
struct ObjectInfo {
|
13
|
+
NftId nftId;
|
14
|
+
NftId parentNftId;
|
15
|
+
ObjectType objectType;
|
16
|
+
address objectAddress;
|
17
|
+
address initialOwner;
|
18
|
+
bytes data;
|
19
|
+
}
|
7
20
|
|
8
|
-
|
21
|
+
function register(address objectAddress) external returns (NftId nftId);
|
9
22
|
|
10
|
-
|
23
|
+
function registerObjectForInstance(
|
24
|
+
NftId parentNftid,
|
25
|
+
ObjectType objectType,
|
26
|
+
address initialOwner,
|
27
|
+
bytes memory data
|
28
|
+
) external returns (NftId nftId);
|
11
29
|
|
12
|
-
function
|
13
|
-
}
|
30
|
+
function getServiceAddress(string memory serviceName, VersionPart majorVersion) external view returns (address serviceAddress);
|
14
31
|
|
15
|
-
|
16
|
-
IOwnable,
|
17
|
-
IRegistryLinked
|
18
|
-
{
|
19
|
-
|
20
|
-
function register() external returns(uint256 nftId);
|
21
|
-
|
22
|
-
function getNftId() external view returns(uint256 nftId);
|
23
|
-
function getParentNftId() external view returns(uint256 parentNftId);
|
24
|
-
function getType() external view returns(uint256 objectType);
|
25
|
-
function getData() external view returns(bytes memory data);
|
26
|
-
function isRegisterable() external pure returns(bool);
|
27
|
-
function getInitialOwner() external view returns(address initialOwner);
|
28
|
-
|
29
|
-
function isRegistered() external view returns(bool);
|
30
|
-
}
|
32
|
+
function getObjectCount() external view returns (uint256);
|
31
33
|
|
34
|
+
function getNftId() external view returns (NftId nftId);
|
32
35
|
|
33
|
-
|
36
|
+
function getNftId(
|
37
|
+
address objectAddress
|
38
|
+
) external view returns (NftId nftId);
|
34
39
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
uint256 objectType;
|
39
|
-
address objectAddress;
|
40
|
-
address initialOwner;
|
41
|
-
}
|
40
|
+
function getObjectInfo(
|
41
|
+
NftId nftId
|
42
|
+
) external view returns (ObjectInfo memory info);
|
42
43
|
|
43
|
-
function
|
44
|
-
|
45
|
-
|
46
|
-
function ORACLE() external pure returns(uint256);
|
47
|
-
function POOL() external pure returns(uint256);
|
48
|
-
function POLICY() external pure returns(uint256);
|
49
|
-
function BUNDLE() external pure returns(uint256);
|
44
|
+
function getName(
|
45
|
+
NftId nftId
|
46
|
+
) external view returns (string memory name);
|
50
47
|
|
51
|
-
function
|
52
|
-
|
53
|
-
|
54
|
-
uint256 objectType,
|
55
|
-
address initialOwner
|
56
|
-
)
|
57
|
-
external returns(uint256 nftId);
|
48
|
+
function getProtocolOwner() external view returns (address);
|
49
|
+
|
50
|
+
function getOwner(NftId nftId) external view returns (address ownerAddress);
|
58
51
|
|
59
|
-
function
|
52
|
+
function isRegistered(NftId nftId) external view returns (bool);
|
60
53
|
|
61
|
-
function
|
62
|
-
function getInfo(uint256 nftId) external view returns(RegistryInfo memory info);
|
63
|
-
function getOwner(uint256 nftId) external view returns(address ownerAddress);
|
54
|
+
function isRegistered(address objectAddress) external view returns (bool);
|
64
55
|
|
65
|
-
function
|
56
|
+
function getChainNft() external view returns (IChainNft);
|
66
57
|
}
|
@@ -1,149 +1,173 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
-
import {
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
4
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
5
|
+
import {IService} from "../instance/base/IService.sol";
|
6
|
+
|
7
|
+
import {IChainNft} from "./IChainNft.sol";
|
8
|
+
import {ChainNft} from "./ChainNft.sol";
|
9
|
+
import {IRegistry} from "./IRegistry.sol";
|
10
|
+
import {NftId, toNftId, zeroNftId, NftIdLib} from "../types/NftId.sol";
|
11
|
+
import {VersionPart} from "../types/Version.sol";
|
12
|
+
import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../types/ObjectType.sol";
|
13
|
+
|
14
|
+
// TODO make registry upgradable
|
15
|
+
contract Registry is
|
16
|
+
IRegisterable,
|
17
|
+
IRegistry
|
18
|
+
{
|
19
|
+
using NftIdLib for NftId;
|
13
20
|
|
14
|
-
|
15
|
-
// require(address(_registry) == address(0), "ERROR:RGL-001:REGISTRY_ALREADY_SET");
|
16
|
-
// _registry = IRegistry(registry);
|
17
|
-
// }
|
21
|
+
string public constant EMPTY_URI = "";
|
18
22
|
|
19
|
-
|
20
|
-
|
21
|
-
|
23
|
+
mapping(NftId nftId => ObjectInfo info) private _info;
|
24
|
+
mapping(NftId nftId => address owner) private _owner;
|
25
|
+
mapping(address object => NftId nftId) private _nftIdByAddress;
|
26
|
+
mapping(ObjectType objectType => bool) private _isValidType;
|
27
|
+
mapping(ObjectType objectType => mapping(ObjectType objectParentType => bool)) private _isValidParentType;
|
22
28
|
|
23
|
-
|
29
|
+
mapping(NftId nftId => string stringValue) private _string;
|
30
|
+
mapping(bytes32 serviceNameHash => mapping(VersionPart majorVersion => address service)) _service;
|
24
31
|
|
32
|
+
NftId private _nftId;
|
33
|
+
IChainNft private _chainNft;
|
34
|
+
ChainNft private _chainNftInternal;
|
35
|
+
address private _initialOwner;
|
25
36
|
|
26
|
-
|
27
|
-
|
28
|
-
IRegisterable
|
29
|
-
{
|
37
|
+
// @dev will own protocol nft and registry nft(s) minted during initialize
|
38
|
+
address private _protocolOwner;
|
30
39
|
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
40
|
+
// TODO refactor once registry becomes upgradable
|
41
|
+
// @Dev the protocol owner will get ownership of the
|
42
|
+
// protocol nft and the global registry nft minted in this
|
43
|
+
// initializer function
|
44
|
+
function initialize(
|
45
|
+
address chainNft,
|
46
|
+
address protocolOwner
|
47
|
+
)
|
48
|
+
public
|
35
49
|
{
|
36
|
-
|
37
|
-
|
50
|
+
require(
|
51
|
+
address(_chainNft) == address(0),
|
52
|
+
"ERROR:REG-001:ALREADY_INITIALIZED"
|
53
|
+
);
|
38
54
|
|
39
|
-
|
55
|
+
_initialOwner = msg.sender;
|
56
|
+
_protocolOwner = protocolOwner;
|
40
57
|
|
41
|
-
|
42
|
-
|
43
|
-
}
|
58
|
+
_chainNft = IChainNft(chainNft);
|
59
|
+
_chainNftInternal = ChainNft(chainNft);
|
44
60
|
|
45
|
-
|
46
|
-
|
47
|
-
|
61
|
+
// initial registry setup
|
62
|
+
_registerProtocol();
|
63
|
+
_nftId = _registerRegistry();
|
48
64
|
|
49
|
-
|
50
|
-
|
65
|
+
// setup rules for further registrations
|
66
|
+
_setupValidTypes();
|
67
|
+
_setupValidParentTypes();
|
51
68
|
}
|
52
69
|
|
53
|
-
function getNftId() public view override returns(uint256 id) {
|
54
|
-
return _registry.getNftId(address(this));
|
55
|
-
}
|
56
70
|
|
57
|
-
function
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
71
|
+
function register(
|
72
|
+
address objectAddress
|
73
|
+
)
|
74
|
+
// TODO add authz (only services may register components etc)
|
75
|
+
// we have to check how we do authz for registring services (just restrict to protocol owner/registry owner)
|
76
|
+
external override returns (NftId nftId) {
|
77
|
+
require(
|
78
|
+
_nftIdByAddress[objectAddress].eqz(),
|
79
|
+
"ERROR:REG-002:ALREADY_REGISTERED"
|
80
|
+
);
|
62
81
|
|
63
|
-
|
82
|
+
IRegisterable registerable = IRegisterable(objectAddress);
|
83
|
+
require(
|
84
|
+
registerable.supportsInterface(type(IRegisterable).interfaceId),
|
85
|
+
"ERROR:REG-003:NOT_REGISTERABLE"
|
86
|
+
);
|
64
87
|
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
// }
|
88
|
+
ObjectType objectType = registerable.getType();
|
89
|
+
require(
|
90
|
+
_isValidType[objectType],
|
91
|
+
"ERROR:REG-004:TYPE_INVALID"
|
92
|
+
);
|
71
93
|
|
72
|
-
|
94
|
+
NftId parentNftId = registerable.getParentNftId();
|
95
|
+
require(
|
96
|
+
isRegistered(parentNftId),
|
97
|
+
"ERROR:REG-005:PARENT_NOT_REGISTERED"
|
98
|
+
);
|
73
99
|
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
uint256 private _idNext;
|
100
|
+
require(
|
101
|
+
_isValidParentType[objectType][_info[parentNftId].objectType],
|
102
|
+
"ERROR:REG-006:PARENT_TYPE_INVALID"
|
103
|
+
);
|
79
104
|
|
105
|
+
// also check that nftId and parentNFtId are on the same chain if applicable
|
80
106
|
|
81
|
-
|
82
|
-
|
83
|
-
|
107
|
+
// nft minting
|
108
|
+
uint256 mintedTokenId = _chainNft.mint(
|
109
|
+
registerable.getOwner(),
|
110
|
+
EMPTY_URI
|
111
|
+
);
|
84
112
|
|
85
|
-
|
86
|
-
function INSTANCE() public pure override returns(uint256) { return 40; }
|
87
|
-
function PRODUCT() public pure override returns(uint256) { return 50; }
|
88
|
-
function ORACLE() public pure override returns(uint256) { return 60; }
|
89
|
-
function POOL() public pure override returns(uint256) { return 70; }
|
90
|
-
function POLICY() public pure override returns(uint256) { return 80; }
|
91
|
-
function BUNDLE() public pure override returns(uint256) { return 90; }
|
113
|
+
nftId = toNftId(mintedTokenId);
|
92
114
|
|
93
|
-
|
94
|
-
|
115
|
+
// special case services
|
116
|
+
if(registerable.getType() == SERVICE()) {
|
117
|
+
IService service = IService(objectAddress);
|
118
|
+
require(
|
119
|
+
service.supportsInterface(type(IService).interfaceId),
|
120
|
+
"ERROR:REG-007:NOT_SERVICE"
|
121
|
+
);
|
95
122
|
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
// check parent exists (for objects not instances)
|
100
|
-
if(registerable.getType() != INSTANCE()) {
|
101
|
-
RegistryInfo memory parentInfo = _info[registerable.getParentNftId()];
|
102
|
-
require(parentInfo.nftId > 0, "ERROR:REG-003:PARENT_NOT_FOUND");
|
103
|
-
// check validity of parent relation, valid relations are
|
104
|
-
// policy -> product, bundle -> pool, product -> instance, pool -> instance
|
105
|
-
}
|
123
|
+
string memory serviceName = service.getName();
|
124
|
+
VersionPart majorVersion = service.getMajorVersion();
|
125
|
+
bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
|
106
126
|
|
107
|
-
|
108
|
-
|
109
|
-
RegistryInfo memory info = RegistryInfo(
|
110
|
-
nftId,
|
111
|
-
registerable.getParentNftId(),
|
112
|
-
registerable.getType(),
|
113
|
-
objectAddress,
|
114
|
-
registerable.getInitialOwner()
|
115
|
-
);
|
127
|
+
// service specific state
|
128
|
+
_string[nftId] = serviceName;
|
116
129
|
|
117
|
-
|
118
|
-
|
130
|
+
require(
|
131
|
+
_service[serviceNameHash][majorVersion] == address(0),
|
132
|
+
"ERROR:REG-008:ALREADY_REGISTERED"
|
133
|
+
);
|
134
|
+
_service[serviceNameHash][majorVersion] = objectAddress;
|
135
|
+
}
|
119
136
|
|
120
|
-
//
|
137
|
+
// create object info and link nft id with it
|
138
|
+
_registerObjectInfo(registerable, nftId);
|
121
139
|
}
|
122
140
|
|
123
141
|
|
124
142
|
function registerObjectForInstance(
|
125
|
-
|
126
|
-
|
127
|
-
address initialOwner
|
143
|
+
NftId parentNftId,
|
144
|
+
ObjectType objectType,
|
145
|
+
address initialOwner,
|
146
|
+
bytes memory data
|
128
147
|
)
|
129
|
-
external
|
148
|
+
external
|
130
149
|
override
|
131
|
-
|
132
|
-
|
150
|
+
returns (
|
151
|
+
// TODO add onlyRegisteredInstance
|
152
|
+
NftId nftId
|
153
|
+
)
|
133
154
|
{
|
134
155
|
// TODO add more validation
|
135
156
|
require(
|
136
157
|
objectType == POLICY() || objectType == BUNDLE(),
|
137
|
-
"ERROR:REG-
|
158
|
+
"ERROR:REG-010:TYPE_INVALID"
|
159
|
+
);
|
138
160
|
|
139
|
-
|
161
|
+
uint256 mintedTokenId = _chainNft.mint(initialOwner, EMPTY_URI);
|
162
|
+
nftId = toNftId(mintedTokenId);
|
140
163
|
|
141
|
-
|
164
|
+
ObjectInfo memory info = ObjectInfo(
|
142
165
|
nftId,
|
143
166
|
parentNftId,
|
144
167
|
objectType,
|
145
168
|
address(0),
|
146
|
-
initialOwner
|
169
|
+
initialOwner,
|
170
|
+
data
|
147
171
|
);
|
148
172
|
|
149
173
|
_info[nftId] = info;
|
@@ -151,47 +175,207 @@ contract Registry is IRegistry {
|
|
151
175
|
// add logging
|
152
176
|
}
|
153
177
|
|
178
|
+
function getObjectCount() external view override returns (uint256) {
|
179
|
+
return _chainNft.totalSupply();
|
180
|
+
}
|
154
181
|
|
155
|
-
function
|
156
|
-
|
157
|
-
|
182
|
+
function getNftId(
|
183
|
+
address object
|
184
|
+
) external view override returns (NftId id) {
|
185
|
+
return _nftIdByAddress[object];
|
186
|
+
}
|
158
187
|
|
159
|
-
|
188
|
+
function isRegistered(
|
189
|
+
NftId nftId
|
190
|
+
) public view override returns (bool) {
|
191
|
+
return _info[nftId].objectType.gtz();
|
160
192
|
}
|
161
193
|
|
194
|
+
function isRegistered(
|
195
|
+
address object
|
196
|
+
) external view override returns (bool) {
|
197
|
+
return _nftIdByAddress[object].gtz();
|
198
|
+
}
|
162
199
|
|
163
|
-
function
|
164
|
-
|
200
|
+
function getObjectInfo(
|
201
|
+
NftId nftId
|
202
|
+
) external view override returns (ObjectInfo memory info) {
|
203
|
+
return _info[nftId];
|
165
204
|
}
|
166
205
|
|
206
|
+
function getName(
|
207
|
+
NftId nftId
|
208
|
+
) external view returns (string memory name) {
|
209
|
+
return _string[nftId];
|
210
|
+
}
|
211
|
+
|
212
|
+
function getOwner(NftId nftId) external view override returns (address) {
|
213
|
+
return _chainNft.ownerOf(nftId.toInt());
|
214
|
+
}
|
167
215
|
|
168
|
-
function
|
169
|
-
return
|
216
|
+
function getChainNft() external view override returns (IChainNft) {
|
217
|
+
return _chainNft;
|
170
218
|
}
|
171
219
|
|
220
|
+
// special case to retrive a gif service
|
221
|
+
function getServiceAddress(string memory serviceName, VersionPart majorVersion) external view override returns (address serviceAddress) {
|
222
|
+
bytes32 serviceNameHash = keccak256(abi.encode(serviceName));
|
223
|
+
return _service[serviceNameHash][majorVersion];
|
224
|
+
}
|
172
225
|
|
173
|
-
|
174
|
-
|
226
|
+
// from IERC165
|
227
|
+
function supportsInterface(bytes4 interfaceId) external pure override returns (bool) {
|
228
|
+
return interfaceId == type(IRegistry).interfaceId;
|
175
229
|
}
|
176
230
|
|
231
|
+
// from IRegistryLinked
|
232
|
+
function getRegistry() external view override returns (IRegistry registry) {
|
233
|
+
return this;
|
234
|
+
}
|
177
235
|
|
178
|
-
|
179
|
-
|
236
|
+
// from IRegisterable
|
237
|
+
function register() external pure override returns (NftId nftId) {
|
238
|
+
return zeroNftId();
|
180
239
|
}
|
181
240
|
|
182
|
-
function
|
183
|
-
return
|
241
|
+
function getType() external pure override returns (ObjectType objectType) {
|
242
|
+
return REGISTRY();
|
184
243
|
}
|
185
244
|
|
186
245
|
|
187
|
-
function
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
246
|
+
function getOwner() public view override returns (address owner) {
|
247
|
+
return _nftId.gtz() ? this.getOwner(_nftId) : _initialOwner;
|
248
|
+
}
|
249
|
+
|
250
|
+
function getNftId() external view override (IRegisterable, IRegistry) returns (NftId nftId) {
|
251
|
+
return _nftId;
|
252
|
+
}
|
253
|
+
|
254
|
+
function getParentNftId() external view returns (NftId nftId) {
|
255
|
+
// we're the global registry
|
256
|
+
if(block.chainid == 1) {
|
257
|
+
return toNftId(_chainNftInternal.PROTOCOL_NFT_ID());
|
258
|
+
}
|
259
|
+
else {
|
260
|
+
return toNftId(_chainNftInternal.GLOBAL_REGISTRY_ID());
|
261
|
+
}
|
262
|
+
}
|
263
|
+
|
264
|
+
function getData() external pure returns (bytes memory data) {
|
265
|
+
return "";
|
266
|
+
}
|
267
|
+
|
268
|
+
// registry specific functions
|
269
|
+
function getProtocolOwner() external view override returns (address) {
|
270
|
+
return _protocolOwner;
|
271
|
+
}
|
272
|
+
|
273
|
+
/// @dev defines which types are allowed to register
|
274
|
+
function _setupValidTypes() internal {
|
275
|
+
_isValidType[REGISTRY()] = true; // only for global registry
|
276
|
+
_isValidType[TOKEN()] = true;
|
277
|
+
_isValidType[SERVICE()] = true;
|
278
|
+
_isValidType[INSTANCE()] = true;
|
279
|
+
_isValidType[STAKE()] = true;
|
280
|
+
_isValidType[PRODUCT()] = true;
|
281
|
+
_isValidType[ORACLE()] = true;
|
282
|
+
_isValidType[POOL()] = true;
|
283
|
+
_isValidType[POLICY()] = true;
|
284
|
+
_isValidType[BUNDLE()] = true;
|
285
|
+
}
|
286
|
+
|
287
|
+
/// @dev defines which types - parent type relations are allowed to register
|
288
|
+
function _setupValidParentTypes() internal {
|
289
|
+
// registry as parent
|
290
|
+
_isValidParentType[TOKEN()][REGISTRY()] = true;
|
291
|
+
_isValidParentType[SERVICE()][REGISTRY()] = true;
|
292
|
+
_isValidParentType[INSTANCE()][REGISTRY()] = true;
|
293
|
+
|
294
|
+
// instance as parent
|
295
|
+
_isValidParentType[PRODUCT()][INSTANCE()] = true;
|
296
|
+
_isValidParentType[DISTRIBUTOR()][INSTANCE()] = true;
|
297
|
+
_isValidParentType[ORACLE()][INSTANCE()] = true;
|
298
|
+
_isValidParentType[POOL()][INSTANCE()] = true;
|
299
|
+
|
300
|
+
// product as parent
|
301
|
+
_isValidParentType[POLICY()][PRODUCT()] = true;
|
302
|
+
|
303
|
+
// pool as parent
|
304
|
+
_isValidParentType[BUNDLE()][POOL()] = true;
|
305
|
+
_isValidParentType[STAKE()][POOL()] = true;
|
306
|
+
}
|
192
307
|
|
193
|
-
|
194
|
-
|
195
|
-
|
308
|
+
/// @dev protocol registration used to anchor the dip ecosystem relations
|
309
|
+
function _registerProtocol() virtual internal {
|
310
|
+
uint256 protocolId = _chainNftInternal.PROTOCOL_NFT_ID();
|
311
|
+
_chainNftInternal.mint(_protocolOwner, protocolId);
|
312
|
+
|
313
|
+
NftId protocolNftid = toNftId(protocolId);
|
314
|
+
ObjectInfo memory protocolInfo = ObjectInfo(
|
315
|
+
protocolNftid,
|
316
|
+
zeroNftId(), // parent nft id
|
317
|
+
PROTOCOL(),
|
318
|
+
address(0), // contract address
|
319
|
+
_protocolOwner,
|
320
|
+
"" // data
|
321
|
+
);
|
322
|
+
|
323
|
+
_info[protocolNftid] = protocolInfo;
|
196
324
|
}
|
325
|
+
|
326
|
+
/// @dev registry registration
|
327
|
+
/// might also register the global registry when not on mainnet
|
328
|
+
function _registerRegistry() virtual internal returns (NftId registryNftId) {
|
329
|
+
uint256 registryId = _chainNftInternal.calculateTokenId(2);
|
330
|
+
registryNftId = toNftId(registryId);
|
331
|
+
|
332
|
+
// we're not the global registry
|
333
|
+
if(registryId != _chainNftInternal.GLOBAL_REGISTRY_ID()) {
|
334
|
+
_registerGlobalRegistry();
|
335
|
+
}
|
336
|
+
|
337
|
+
_chainNftInternal.mint(_protocolOwner, registryId);
|
338
|
+
_registerObjectInfo(this, registryNftId);
|
339
|
+
}
|
340
|
+
|
341
|
+
|
342
|
+
/// @dev global registry registration for non mainnet registries
|
343
|
+
function _registerGlobalRegistry() virtual internal {
|
344
|
+
uint256 globalRegistryId = _chainNftInternal.GLOBAL_REGISTRY_ID();
|
345
|
+
_chainNftInternal.mint(_protocolOwner, globalRegistryId);
|
346
|
+
|
347
|
+
NftId globalRegistryNftId = toNftId(globalRegistryId);
|
348
|
+
ObjectInfo memory globalRegistryInfo = ObjectInfo(
|
349
|
+
globalRegistryNftId,
|
350
|
+
toNftId(_chainNftInternal.PROTOCOL_NFT_ID()),
|
351
|
+
REGISTRY(),
|
352
|
+
address(0), // contract address
|
353
|
+
_protocolOwner,
|
354
|
+
"" // data
|
355
|
+
);
|
356
|
+
|
357
|
+
_info[globalRegistryNftId] = globalRegistryInfo;
|
358
|
+
}
|
359
|
+
|
360
|
+
|
361
|
+
function _registerObjectInfo(
|
362
|
+
IRegisterable registerable,
|
363
|
+
NftId nftId
|
364
|
+
) internal virtual {
|
365
|
+
address objectAddress = address(registerable);
|
366
|
+
ObjectInfo memory info = ObjectInfo(
|
367
|
+
nftId,
|
368
|
+
registerable.getParentNftId(),
|
369
|
+
registerable.getType(),
|
370
|
+
objectAddress,
|
371
|
+
registerable.getOwner(),
|
372
|
+
registerable.getData()
|
373
|
+
);
|
374
|
+
|
375
|
+
_info[nftId] = info;
|
376
|
+
_nftIdByAddress[objectAddress] = nftId;
|
377
|
+
|
378
|
+
// add logging
|
379
|
+
}
|
380
|
+
|
197
381
|
}
|
@@ -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
|
+
}
|