@etherisc/gif-next 0.0.2-ce87da3-250 → 0.0.2-cf22d7b-845
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 +8 -84
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +322 -252
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1349 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +818 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +249 -174
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +266 -91
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +68 -54
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +315 -2127
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +219 -78
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +456 -2872
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +204 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +601 -422
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +287 -280
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +119 -78
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3458 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +6 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +25 -150
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{ISetup.sol/ISetup.json → IComponents.sol/IComponents.json} +2 -2
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1105 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +746 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +278 -221
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +480 -213
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1065 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +527 -284
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1432 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +738 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +834 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +722 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1278 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +810 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IApplicationService.sol/IApplicationService.json +124 -98
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +759 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +266 -142
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +536 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +408 -219
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +75 -72
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1146 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +754 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +983 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +778 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/Product.sol/Product.json +433 -282
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +679 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +694 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +15 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +188 -19
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +305 -85
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +18 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +425 -34
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +344 -106
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +93 -54
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +834 -89
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +316 -153
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/Component.sol/Component.json +209 -166
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1475 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +788 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +96 -122
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +222 -104
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +860 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +705 -0
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -11
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +3 -10
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +87 -9
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +3 -10
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +91 -27
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1036 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -22
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +98 -26
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +70 -35
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +24 -23
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +99 -30
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +60 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1438 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +993 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +444 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2045 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +777 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1324 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +726 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2189 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/AddressSet.sol/LibAddressSet.json +3 -3
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +345 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +225 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/DistributorType.sol/DistributorTypeLib.json +5 -5
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Key32.sol/Key32Lib.json +3 -3
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +209 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/NftIdSet.sol/LibNftIdSet.json +3 -3
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/ObjectType.sol/ObjectTypeLib.json +3 -3
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RiskId.sol/RiskIdLib.json +5 -5
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/RoleId.sol/RoleIdLib.json +5 -5
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +198 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/StateId.sol/StateIdLib.json +3 -3
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Timestamp.sol/TimestampLib.json +39 -8
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/{components → distribution}/Distribution.sol +49 -75
- package/contracts/distribution/DistributionService.sol +298 -0
- package/contracts/distribution/DistributionServiceManager.sol +42 -0
- package/contracts/{components → distribution}/IDistributionComponent.sol +11 -37
- package/contracts/{instance/service → distribution}/IDistributionService.sol +25 -25
- package/contracts/instance/BundleManager.sol +15 -14
- package/contracts/instance/IInstance.sol +53 -66
- package/contracts/instance/IInstanceService.sol +40 -18
- package/contracts/instance/Instance.sol +139 -195
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +349 -0
- package/contracts/instance/InstanceReader.sol +135 -63
- package/contracts/instance/InstanceService.sol +226 -340
- package/contracts/instance/InstanceServiceManager.sol +11 -21
- package/contracts/instance/InstanceStore.sol +260 -0
- package/contracts/instance/base/BalanceStore.sol +118 -0
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +8 -3
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +12 -14
- package/contracts/instance/module/IAccess.sol +19 -20
- package/contracts/instance/module/IBundle.sol +8 -8
- package/contracts/instance/module/{ISetup.sol → IComponents.sol} +24 -20
- package/contracts/instance/module/IDistribution.sol +7 -5
- package/contracts/instance/module/IPolicy.sol +53 -16
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/{test/TestToken.sol → mock/Dip.sol} +5 -5
- package/contracts/pool/BundleService.sol +296 -0
- package/contracts/pool/BundleServiceManager.sol +42 -0
- package/contracts/pool/IBundleService.sol +106 -0
- package/contracts/pool/IPoolComponent.sol +112 -0
- package/contracts/pool/IPoolService.sol +150 -0
- package/contracts/pool/Pool.sol +299 -0
- package/contracts/pool/PoolService.sol +453 -0
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +254 -0
- package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
- package/contracts/product/ClaimService.sol +442 -0
- package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
- package/contracts/{instance/service → product}/IApplicationService.sol +16 -36
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/{instance/service → product}/IPolicyService.sol +37 -48
- package/contracts/product/IPricingService.sol +39 -0
- package/contracts/product/IProductComponent.sol +42 -0
- package/contracts/product/IProductService.sol +33 -0
- package/contracts/product/PolicyService.sol +475 -0
- package/contracts/product/PolicyServiceManager.sol +42 -0
- package/contracts/product/PricingService.sol +301 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/product/Product.sol +377 -0
- package/contracts/product/ProductService.sol +124 -0
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/ChainNft.sol +16 -1
- package/contracts/registry/IRegistry.sol +46 -21
- package/contracts/registry/IRegistryService.sol +39 -37
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +208 -96
- package/contracts/registry/RegistryAdmin.sol +237 -0
- package/contracts/registry/RegistryService.sol +69 -86
- package/contracts/registry/RegistryServiceManager.sol +21 -25
- package/contracts/registry/ReleaseManager.sol +458 -181
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +261 -62
- package/contracts/shared/AccessManagerCustom.sol +736 -0
- package/contracts/shared/AccessManagerExtended.sol +470 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/shared/Component.sol +278 -0
- package/contracts/shared/ComponentService.sol +596 -0
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +111 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +70 -0
- package/contracts/shared/IComponentService.sol +91 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +15 -11
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +2 -2
- package/contracts/shared/IPolicyHolder.sol +29 -10
- package/contracts/shared/IRegistryLinked.sol +0 -1
- package/contracts/shared/IService.sol +7 -7
- package/contracts/shared/IVersionable.sol +1 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/shared/KeyValueStore.sol +127 -0
- package/contracts/{instance/base → shared}/Lifecycle.sol +28 -7
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +3 -16
- package/contracts/shared/PolicyHolder.sol +40 -19
- package/contracts/shared/ProxyManager.sol +34 -4
- package/contracts/shared/Registerable.sol +15 -14
- package/contracts/shared/RegistryLinked.sol +0 -5
- package/contracts/shared/Service.sol +29 -10
- package/contracts/shared/TokenHandler.sol +37 -6
- package/contracts/shared/Versionable.sol +1 -1
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +149 -0
- package/contracts/staking/StakeManagerLib.sol +179 -0
- package/contracts/staking/Staking.sol +551 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +406 -0
- package/contracts/staking/StakingServiceManager.sol +45 -0
- package/contracts/staking/StakingStore.sol +572 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/{types → type}/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +128 -0
- package/contracts/{types → type}/Blocknumber.sol +21 -3
- package/contracts/{types → type}/ClaimId.sol +25 -2
- package/contracts/{types → type}/Fee.sol +33 -23
- package/contracts/{types → type}/NftId.sol +21 -15
- package/contracts/{types → type}/NftIdSet.sol +2 -2
- package/contracts/{types → type}/ObjectType.sol +20 -7
- package/contracts/{types → type}/PayoutId.sol +33 -5
- package/contracts/{types → type}/Referral.sol +5 -1
- package/contracts/{types → type}/RiskId.sol +1 -1
- package/contracts/{types → type}/RoleId.sol +66 -13
- package/contracts/type/Seconds.sol +81 -0
- package/contracts/{types → type}/StateId.sol +24 -6
- package/contracts/{types → type}/Timestamp.sol +18 -13
- package/contracts/{types → type}/UFixed.sol +1 -0
- package/contracts/{types → type}/Version.sol +2 -1
- package/package.json +3 -3
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -984
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +0 -261
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -502
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -169
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -869
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -657
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1096
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -661
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -754
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -637
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1254
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -753
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +0 -409
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +0 -347
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +0 -1120
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -717
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -727
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -649
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -777
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -649
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -521
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -257
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -153
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +0 -123
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +0 -4
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +0 -4
- package/contracts/components/Component.sol +0 -241
- package/contracts/components/IComponent.sol +0 -54
- package/contracts/components/IPoolComponent.sol +0 -87
- package/contracts/components/IProductComponent.sol +0 -39
- package/contracts/components/Pool.sol +0 -254
- package/contracts/components/Product.sol +0 -285
- package/contracts/instance/InstanceAccessManager.sol +0 -297
- package/contracts/instance/base/ComponentService.sol +0 -134
- package/contracts/instance/base/KeyValueStore.sol +0 -172
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/instance/service/ApplicationService.sol +0 -268
- package/contracts/instance/service/BundleService.sol +0 -298
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/ClaimService.sol +0 -151
- package/contracts/instance/service/DistributionService.sol +0 -366
- package/contracts/instance/service/DistributionServiceManager.sol +0 -51
- package/contracts/instance/service/IBundleService.sol +0 -54
- package/contracts/instance/service/IClaimService.sol +0 -61
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/IProductService.sol +0 -40
- package/contracts/instance/service/PolicyService.sol +0 -476
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -109
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -233
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- package/contracts/registry/RegistryAccessManager.sol +0 -216
- package/contracts/shared/ContractDeployerLib.sol +0 -72
- package/contracts/test/TestFee.sol +0 -25
- package/contracts/test/TestRegisterable.sol +0 -18
- package/contracts/test/TestRoleId.sol +0 -14
- package/contracts/test/TestService.sol +0 -25
- package/contracts/test/TestVersion.sol +0 -44
- package/contracts/test/TestVersionable.sol +0 -17
- package/contracts/test/Usdc.sol +0 -26
- package/contracts/types/ChainId.sol +0 -38
- package/contracts/types/NumberId.sol +0 -52
- /package/contracts/{types → type}/DistributorType.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
@@ -1,54 +1,55 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
4
|
+
// import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
5
5
|
|
6
|
-
import {NftId} from "../
|
7
|
-
import {ObjectType} from "../
|
8
|
-
import {RoleId} from "../
|
6
|
+
import {NftId} from "../type/NftId.sol";
|
7
|
+
import {ObjectType} from "../type/ObjectType.sol";
|
8
|
+
import {RoleId} from "../type/RoleId.sol";
|
9
9
|
import {IService} from "../shared/IService.sol";
|
10
10
|
import {IRegistry} from "./IRegistry.sol";
|
11
11
|
|
12
12
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
13
|
-
import {IComponent} from "../
|
13
|
+
import {IComponent} from "../shared/IComponent.sol";
|
14
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
15
|
+
|
14
16
|
|
15
17
|
interface IRegistryService is
|
16
|
-
IService
|
17
|
-
IAccessManaged
|
18
|
+
IService
|
18
19
|
{
|
19
|
-
error
|
20
|
-
|
21
|
-
|
22
|
-
error
|
23
|
-
error
|
24
|
-
error
|
25
|
-
error
|
26
|
-
error
|
27
|
-
|
28
|
-
error
|
29
|
-
error
|
30
|
-
error
|
31
|
-
error
|
32
|
-
error
|
33
|
-
error
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
returns(
|
45
|
-
|
46
|
-
);
|
47
|
-
|
48
|
-
// TODO used by service -> add owner arg
|
20
|
+
error ErrorRegistryServiceNotRegistryOwner();
|
21
|
+
|
22
|
+
error ErrorRegistryServiceNotService(address notService);
|
23
|
+
error ErrorRegistryServiceNotInstance(address notInstance);
|
24
|
+
error ErrorRegistryServiceNotComponent(address notComponent);
|
25
|
+
error ErrorRegistryServiceNotProduct(address notProduct);
|
26
|
+
error ErrorRegistryServiceNotPool(address notPool);
|
27
|
+
error ErrorRegistryServiceNotDistribution(address notDistribution);
|
28
|
+
|
29
|
+
error ErrorRegistryServiceRegisterableAddressInvalid(IRegisterable registerable, address found);
|
30
|
+
error ErrorRegistryServiceRegisterableTypeInvalid(IRegisterable registerable, ObjectType expected, ObjectType found);
|
31
|
+
error ErrorRegistryServiceRegisterableOwnerInvalid(IRegisterable registerable, address expected, address found);
|
32
|
+
error ErrorRegistryServiceRegisterableOwnerZero(IRegisterable registerable);
|
33
|
+
error ErrorRegistryServiceRegisterableOwnerRegistered(IRegisterable registerable, address owner);
|
34
|
+
error ErrorRegistryServiceRegisterableSelfRegistration(IRegisterable registerable);
|
35
|
+
|
36
|
+
error ErrorRegistryServiceObjectAddressNotZero(ObjectType objectType);
|
37
|
+
error ErrorRegistryServiceObjectTypeInvalid(ObjectType expected, ObjectType found);
|
38
|
+
error ErrorRegistryServiceObjectOwnerRegistered(ObjectType objectType, address owner);
|
39
|
+
error ErrorRegistryServiceObjectOwnerZero(ObjectType objectType);
|
40
|
+
|
41
|
+
error ErrorRegistryServiceInvalidInitialOwner(address initialOwner);
|
42
|
+
error ErrorRegistryServiceInvalidAddress(address registerableAddress);
|
43
|
+
|
44
|
+
function registerStake(IRegistry.ObjectInfo memory info)
|
45
|
+
external returns(NftId nftId);
|
46
|
+
|
49
47
|
function registerInstance(IRegisterable instance, address owner)
|
50
48
|
external returns(IRegistry.ObjectInfo memory info);
|
51
49
|
|
50
|
+
function registerComponent(IComponent component, ObjectType objectType, address owner)
|
51
|
+
external returns(IRegistry.ObjectInfo memory info);
|
52
|
+
|
52
53
|
function registerProduct(IComponent product, address owner)
|
53
54
|
external returns(IRegistry.ObjectInfo memory info);
|
54
55
|
|
@@ -63,5 +64,6 @@ interface IRegistryService is
|
|
63
64
|
function registerPolicy(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
|
64
65
|
|
65
66
|
function registerBundle(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
|
67
|
+
|
66
68
|
}
|
67
69
|
|
@@ -2,14 +2,20 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
6
|
|
6
|
-
import {
|
7
|
-
|
8
|
-
import {
|
7
|
+
import {InitializableCustom} from "../shared/InitializableCustom.sol";
|
8
|
+
|
9
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
10
|
+
import {VersionPart} from "../type/Version.sol";
|
11
|
+
import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, STAKING, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../type/ObjectType.sol";
|
9
12
|
|
10
13
|
import {ChainNft} from "./ChainNft.sol";
|
11
14
|
import {IRegistry} from "./IRegistry.sol";
|
15
|
+
import {IRegisterable} from "../shared/IRegisterable.sol";
|
12
16
|
import {ReleaseManager} from "./ReleaseManager.sol";
|
17
|
+
import {TokenRegistry} from "./TokenRegistry.sol";
|
18
|
+
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
13
19
|
|
14
20
|
// IMPORTANT
|
15
21
|
// Each NFT minted by registry is accosiated with:
|
@@ -22,10 +28,12 @@ import {ReleaseManager} from "./ReleaseManager.sol";
|
|
22
28
|
// 4) state object by regular service (POLICY, BUNDLE, STAKE)
|
23
29
|
|
24
30
|
contract Registry is
|
31
|
+
InitializableCustom,
|
25
32
|
IRegistry
|
26
33
|
{
|
27
|
-
address public
|
34
|
+
address public NFT_LOCK_ADDRESS = address(0x1);
|
28
35
|
uint256 public constant REGISTRY_TOKEN_SEQUENCE_ID = 2;
|
36
|
+
uint256 public constant STAKING_TOKEN_SEQUENCE_ID = 3;
|
29
37
|
string public constant EMPTY_URI = "";
|
30
38
|
|
31
39
|
mapping(NftId nftId => ObjectInfo info) private _info;
|
@@ -41,40 +49,66 @@ contract Registry is
|
|
41
49
|
mapping(ObjectType objectType => mapping(
|
42
50
|
ObjectType parentType => bool)) private _coreObjectCombinations;
|
43
51
|
|
44
|
-
|
45
|
-
ChainNft
|
52
|
+
RegistryAdmin public immutable _admin;
|
53
|
+
ChainNft public immutable _chainNft;
|
54
|
+
|
55
|
+
NftId public immutable _protocolNftId;
|
56
|
+
NftId public immutable _registryNftId;
|
57
|
+
NftId public _stakingNftId;
|
46
58
|
|
47
|
-
|
59
|
+
address public _tokenRegistryAddress;
|
60
|
+
address public _stakingAddress;
|
61
|
+
ReleaseManager public _releaseManager;
|
48
62
|
|
49
63
|
modifier onlyRegistryService() {
|
50
64
|
if(!_releaseManager.isActiveRegistryService(msg.sender)) {
|
51
|
-
revert
|
65
|
+
revert ErrorRegistryCallerNotRegistryService();
|
52
66
|
}
|
53
67
|
_;
|
54
68
|
}
|
55
69
|
|
70
|
+
|
56
71
|
modifier onlyReleaseManager() {
|
57
72
|
if(msg.sender != address(_releaseManager)) {
|
58
|
-
revert
|
73
|
+
revert ErrorRegistryCallerNotReleaseManager();
|
59
74
|
}
|
60
75
|
_;
|
61
76
|
}
|
62
77
|
|
63
|
-
constructor()
|
64
|
-
{
|
65
|
-
_releaseManager = ReleaseManager(msg.sender);
|
66
78
|
|
79
|
+
constructor(RegistryAdmin admin)
|
80
|
+
InitializableCustom()
|
81
|
+
{
|
82
|
+
_admin = admin;
|
67
83
|
// deploy NFT
|
68
84
|
_chainNft = new ChainNft(address(this));
|
69
85
|
|
70
86
|
// initial registry setup
|
71
|
-
_registerProtocol();
|
72
|
-
_registerRegistry();
|
87
|
+
_protocolNftId = _registerProtocol();
|
88
|
+
_registryNftId = _registerRegistry();
|
73
89
|
|
74
90
|
// set object types and object parent relations
|
75
91
|
_setupValidCoreTypesAndCombinations();
|
76
92
|
}
|
77
93
|
|
94
|
+
|
95
|
+
/// @dev wires release manager and token to registry (this contract).
|
96
|
+
/// MUST be called by release manager.
|
97
|
+
function initialize(
|
98
|
+
address releaseManager,
|
99
|
+
address tokenRegistry,
|
100
|
+
address staking
|
101
|
+
)
|
102
|
+
external
|
103
|
+
initializer()
|
104
|
+
{
|
105
|
+
_releaseManager = ReleaseManager(releaseManager);
|
106
|
+
_tokenRegistryAddress = tokenRegistry;
|
107
|
+
_stakingAddress = staking;
|
108
|
+
|
109
|
+
_stakingNftId = _registerStaking();
|
110
|
+
}
|
111
|
+
|
78
112
|
function registerService(
|
79
113
|
ObjectInfo memory info,
|
80
114
|
VersionPart version,
|
@@ -84,7 +118,16 @@ contract Registry is
|
|
84
118
|
onlyReleaseManager
|
85
119
|
returns(NftId nftId)
|
86
120
|
{
|
121
|
+
address service = info.objectAddress;
|
87
122
|
/* must be guaranteed by release manager
|
123
|
+
if(service == address(0)) {
|
124
|
+
revert();
|
125
|
+
}
|
126
|
+
|
127
|
+
if(version.eqz()) {
|
128
|
+
revert();
|
129
|
+
}
|
130
|
+
|
88
131
|
if(info.objectType != SERVICE()) {
|
89
132
|
revert();
|
90
133
|
}
|
@@ -94,11 +137,15 @@ contract Registry is
|
|
94
137
|
info.initialOwner == NFT_LOCK_ADDRESS <- if services are access managed
|
95
138
|
*/
|
96
139
|
|
97
|
-
if(
|
98
|
-
revert
|
140
|
+
if(domain.eqz()) {
|
141
|
+
revert ErrorRegistryDomainZero(service);
|
99
142
|
}
|
100
143
|
|
101
|
-
_service[version][domain]
|
144
|
+
if(_service[version][domain] > address(0)) {
|
145
|
+
revert ErrorRegistryDomainAlreadyRegistered(service, version, domain);
|
146
|
+
}
|
147
|
+
|
148
|
+
_service[version][domain] = service;
|
102
149
|
|
103
150
|
nftId = _register(info);
|
104
151
|
|
@@ -113,23 +160,17 @@ contract Registry is
|
|
113
160
|
ObjectType objectType = info.objectType;
|
114
161
|
ObjectType parentType = _info[info.parentNftId].objectType;
|
115
162
|
|
116
|
-
// TODO do not need it here -> SERVICE is no longer part of _coreContractCombinations
|
117
|
-
// no service registrations
|
118
|
-
if(objectType == SERVICE()) {
|
119
|
-
revert ServiceRegistration();
|
120
|
-
}
|
121
|
-
|
122
163
|
// only valid core types combinations
|
123
164
|
if(info.objectAddress == address(0))
|
124
165
|
{
|
125
166
|
if(_coreObjectCombinations[objectType][parentType] == false) {
|
126
|
-
revert
|
167
|
+
revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
|
127
168
|
}
|
128
169
|
}
|
129
170
|
else
|
130
171
|
{
|
131
172
|
if(_coreContractCombinations[objectType][parentType] == false) {
|
132
|
-
revert
|
173
|
+
revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
|
133
174
|
}
|
134
175
|
}
|
135
176
|
|
@@ -145,16 +186,15 @@ contract Registry is
|
|
145
186
|
ObjectType parentType = _info[info.parentNftId].objectType;
|
146
187
|
|
147
188
|
if(_coreTypes[objectType]) {
|
148
|
-
revert
|
189
|
+
revert ErrorRegistryCoreTypeRegistration();
|
149
190
|
}
|
150
191
|
|
151
192
|
if(
|
152
|
-
|
153
193
|
parentType == PROTOCOL() ||
|
154
194
|
parentType == REGISTRY() ||
|
155
195
|
parentType == SERVICE()
|
156
196
|
) {
|
157
|
-
revert
|
197
|
+
revert ErrorRegistryTypesCombinationInvalid(objectType, parentType);
|
158
198
|
}
|
159
199
|
|
160
200
|
_register(info);
|
@@ -166,13 +206,7 @@ contract Registry is
|
|
166
206
|
return _releaseManager.getInitialVersion();
|
167
207
|
}
|
168
208
|
|
169
|
-
|
170
|
-
// need to be thought trough, not yet clear if necessary
|
171
|
-
// need to answer question: what is the latest version during the upgrade process?
|
172
|
-
// likely setting up a new gif version does not fit into a single tx
|
173
|
-
// in this case we might want to have a period where the latest version is
|
174
|
-
// in the process of being set up while the latest active version is 1 major release smaller
|
175
|
-
/// @dev latest GIF major version (might not yet be active)
|
209
|
+
/// @dev next GIF release version to be released
|
176
210
|
function getNextVersion() external view returns (VersionPart) {
|
177
211
|
return _releaseManager.getNextVersion();
|
178
212
|
}
|
@@ -186,23 +220,23 @@ contract Registry is
|
|
186
220
|
return _releaseManager.getReleaseInfo(version);
|
187
221
|
}
|
188
222
|
|
189
|
-
function getObjectCount() external view
|
223
|
+
function getObjectCount() external view returns (uint256) {
|
190
224
|
return _chainNft.totalSupply();
|
191
225
|
}
|
192
226
|
|
193
|
-
function getReleaseManagerAddress() external view returns (address) {
|
194
|
-
return address(_releaseManager);
|
195
|
-
}
|
196
|
-
|
197
227
|
function getNftId() external view returns (NftId nftId) {
|
198
228
|
return _registryNftId;
|
199
229
|
}
|
200
230
|
|
201
|
-
function
|
231
|
+
function getProtocolNftId() external view returns (NftId nftId) {
|
232
|
+
return _protocolNftId;
|
233
|
+
}
|
234
|
+
|
235
|
+
function getNftId(address object) external view returns (NftId id) {
|
202
236
|
return _nftIdByAddress[object];
|
203
237
|
}
|
204
238
|
|
205
|
-
function ownerOf(NftId nftId) public view
|
239
|
+
function ownerOf(NftId nftId) public view returns (address) {
|
206
240
|
return _chainNft.ownerOf(nftId.toInt());
|
207
241
|
}
|
208
242
|
|
@@ -210,29 +244,44 @@ contract Registry is
|
|
210
244
|
return _chainNft.ownerOf(_nftIdByAddress[contractAddress].toInt());
|
211
245
|
}
|
212
246
|
|
213
|
-
function getObjectInfo(NftId nftId) external view
|
247
|
+
function getObjectInfo(NftId nftId) external view returns (ObjectInfo memory) {
|
214
248
|
return _info[nftId];
|
215
249
|
}
|
216
250
|
|
217
|
-
function getObjectInfo(address object) external view
|
251
|
+
function getObjectInfo(address object) external view returns (ObjectInfo memory) {
|
218
252
|
return _info[_nftIdByAddress[object]];
|
219
253
|
}
|
220
254
|
|
221
|
-
function isRegistered(NftId nftId) public view
|
255
|
+
function isRegistered(NftId nftId) public view returns (bool) {
|
222
256
|
return _info[nftId].objectType.gtz();
|
223
257
|
}
|
224
258
|
|
225
|
-
function isRegistered(address object) external view
|
259
|
+
function isRegistered(address object) external view returns (bool) {
|
226
260
|
return _nftIdByAddress[object].gtz();
|
227
261
|
}
|
228
262
|
|
229
|
-
function isRegisteredService(address object) external view
|
263
|
+
function isRegisteredService(address object) external view returns (bool) {
|
230
264
|
return _info[_nftIdByAddress[object]].objectType == SERVICE();
|
231
265
|
}
|
232
266
|
|
233
|
-
function
|
267
|
+
function isRegisteredComponent(address object) external view returns (bool) {
|
268
|
+
NftId objectParentNftId = _info[_nftIdByAddress[object]].parentNftId;
|
269
|
+
return _info[objectParentNftId].objectType == INSTANCE();
|
270
|
+
}
|
271
|
+
|
272
|
+
function isActiveRelease(VersionPart version) external view returns (bool)
|
234
273
|
{
|
235
|
-
return _releaseManager.
|
274
|
+
return _releaseManager.isActiveRelease(version);
|
275
|
+
}
|
276
|
+
|
277
|
+
function getStakingAddress() external view returns (address staking) {
|
278
|
+
//return getObjectInfo(_stakingNftId).objectAddress;
|
279
|
+
//return _info[_stakingNftId].objectAddress;
|
280
|
+
return _stakingAddress;
|
281
|
+
}
|
282
|
+
|
283
|
+
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
284
|
+
return _tokenRegistryAddress;
|
236
285
|
}
|
237
286
|
|
238
287
|
function getServiceAddress(
|
@@ -240,16 +289,29 @@ contract Registry is
|
|
240
289
|
VersionPart releaseVersion
|
241
290
|
) external view returns (address service)
|
242
291
|
{
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
292
|
+
service = _service[releaseVersion][serviceDomain];
|
293
|
+
}
|
294
|
+
|
295
|
+
function getReleaseAccessManagerAddress(VersionPart version) external view returns (address) {
|
296
|
+
return address(_releaseManager.getReleaseAccessManager(version));
|
297
|
+
}
|
298
|
+
|
299
|
+
function getReleaseManagerAddress() external view returns (address) {
|
300
|
+
return address(_releaseManager);
|
247
301
|
}
|
248
302
|
|
249
303
|
function getChainNftAddress() external view override returns (address) {
|
250
304
|
return address(_chainNft);
|
251
305
|
}
|
252
306
|
|
307
|
+
function getRegistryAdminAddress() external view returns (address) {
|
308
|
+
return address(_admin);
|
309
|
+
}
|
310
|
+
|
311
|
+
function getAuthority() external view returns (address) {
|
312
|
+
return _admin.authority();
|
313
|
+
}
|
314
|
+
|
253
315
|
function getOwner() public view returns (address owner) {
|
254
316
|
return ownerOf(address(this));
|
255
317
|
}
|
@@ -273,60 +335,76 @@ contract Registry is
|
|
273
335
|
returns(NftId nftId)
|
274
336
|
{
|
275
337
|
ObjectType objectType = info.objectType;
|
338
|
+
bool isInterceptor = info.isInterceptor;
|
339
|
+
address objectAddress = info.objectAddress;
|
340
|
+
address owner = info.initialOwner;
|
341
|
+
|
276
342
|
NftId parentNftId = info.parentNftId;
|
277
343
|
ObjectInfo memory parentInfo = _info[parentNftId];
|
278
344
|
ObjectType parentType = parentInfo.objectType; // see function header
|
279
345
|
address parentAddress = parentInfo.objectAddress;
|
280
346
|
|
281
347
|
// parent is contract -> need to check? -> check before minting
|
348
|
+
// special case: staking: to protocol possible as well
|
282
349
|
// special case: global registry nft as parent when not on mainnet -> global registry address is 0
|
283
350
|
// special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
|
284
351
|
// special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
|
285
|
-
if(
|
286
|
-
|
352
|
+
if(objectType != STAKE()) {
|
353
|
+
if(parentAddress == address(0)) {
|
354
|
+
revert ErrorRegistryParentAddressZero();
|
355
|
+
}
|
287
356
|
}
|
288
357
|
|
289
|
-
address
|
358
|
+
address interceptorAddress = _getInterceptor(
|
359
|
+
isInterceptor,
|
360
|
+
objectType,
|
361
|
+
objectAddress,
|
362
|
+
parentInfo.isInterceptor,
|
363
|
+
parentAddress);
|
290
364
|
|
291
|
-
|
292
|
-
|
293
|
-
uint256 mintedTokenId = _chainNft.mint(
|
294
|
-
info.initialOwner,
|
295
|
-
interceptor,
|
296
|
-
EMPTY_URI);
|
297
|
-
nftId = toNftId(mintedTokenId);
|
298
|
-
|
299
|
-
// TODO move nftId out of info struct
|
300
|
-
// getters by nftId -> return struct without nftId
|
301
|
-
// getters by address -> return nftId AND struct
|
365
|
+
uint256 tokenId = _chainNft.getNextTokenId();
|
366
|
+
nftId = NftIdLib.toNftId(tokenId);
|
302
367
|
info.nftId = nftId;
|
303
368
|
_info[nftId] = info;
|
304
369
|
|
305
|
-
if(
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
if(_nftIdByAddress[contractAddress].gtz()) {
|
310
|
-
revert ContractAlreadyRegistered(contractAddress);
|
370
|
+
if(objectAddress > address(0)) {
|
371
|
+
if(_nftIdByAddress[objectAddress].gtz()) {
|
372
|
+
revert ErrorRegistryContractAlreadyRegistered(objectAddress);
|
311
373
|
}
|
312
374
|
|
313
|
-
_nftIdByAddress[
|
375
|
+
_nftIdByAddress[objectAddress] = nftId;
|
314
376
|
}
|
315
377
|
|
316
|
-
emit LogRegistration(nftId, parentNftId, objectType,
|
378
|
+
emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
|
379
|
+
|
380
|
+
// calls nft receiver(1) and interceptor(2)
|
381
|
+
uint256 mintedTokenId = _chainNft.mint(
|
382
|
+
owner,
|
383
|
+
interceptorAddress,
|
384
|
+
EMPTY_URI);
|
385
|
+
|
386
|
+
assert(mintedTokenId == tokenId);
|
317
387
|
}
|
318
388
|
|
319
389
|
/// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
|
390
|
+
/// special case: STAKES (parent may be any type) -> no intercept call
|
391
|
+
/// default case:
|
320
392
|
function _getInterceptor(
|
321
393
|
bool isInterceptor,
|
394
|
+
ObjectType objectType,
|
322
395
|
address objectAddress,
|
323
396
|
bool parentIsInterceptor,
|
324
397
|
address parentObjectAddress
|
325
398
|
)
|
326
399
|
internal
|
327
|
-
|
400
|
+
pure
|
328
401
|
returns (address interceptor)
|
329
402
|
{
|
403
|
+
// no intercepting calls for stakes
|
404
|
+
if (objectType == STAKE()) {
|
405
|
+
return address(0);
|
406
|
+
}
|
407
|
+
|
330
408
|
if (objectAddress == address(0)) {
|
331
409
|
if (parentIsInterceptor) {
|
332
410
|
return parentObjectAddress;
|
@@ -347,13 +425,14 @@ contract Registry is
|
|
347
425
|
/// @dev protocol registration used to anchor the dip ecosystem relations
|
348
426
|
function _registerProtocol()
|
349
427
|
private
|
428
|
+
returns (NftId protocolNftId)
|
350
429
|
{
|
351
430
|
uint256 protocolId = _chainNft.PROTOCOL_NFT_ID();
|
352
|
-
|
431
|
+
protocolNftId = NftIdLib.toNftId(protocolId);
|
353
432
|
|
354
433
|
_info[protocolNftId] = ObjectInfo({
|
355
434
|
nftId: protocolNftId,
|
356
|
-
parentNftId:
|
435
|
+
parentNftId: NftIdLib.zero(),
|
357
436
|
objectType: PROTOCOL(),
|
358
437
|
isInterceptor: false,
|
359
438
|
objectAddress: address(0),
|
@@ -368,19 +447,20 @@ contract Registry is
|
|
368
447
|
/// might also register the global registry when not on mainnet
|
369
448
|
function _registerRegistry()
|
370
449
|
private
|
450
|
+
returns (NftId registryNftId)
|
371
451
|
{
|
372
452
|
uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
|
373
|
-
|
453
|
+
registryNftId = NftIdLib.toNftId(registryId);
|
374
454
|
NftId parentNftId;
|
375
455
|
|
376
456
|
if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
|
377
457
|
{// we're not the global registry
|
378
458
|
_registerGlobalRegistry();
|
379
|
-
parentNftId = toNftId(_chainNft.GLOBAL_REGISTRY_ID());
|
459
|
+
parentNftId = NftIdLib.toNftId(_chainNft.GLOBAL_REGISTRY_ID());
|
380
460
|
}
|
381
461
|
else
|
382
462
|
{// we are global registry
|
383
|
-
parentNftId =
|
463
|
+
parentNftId = _protocolNftId;
|
384
464
|
}
|
385
465
|
|
386
466
|
_info[registryNftId] = ObjectInfo({
|
@@ -392,9 +472,8 @@ contract Registry is
|
|
392
472
|
initialOwner: NFT_LOCK_ADDRESS,
|
393
473
|
data: ""
|
394
474
|
});
|
395
|
-
_nftIdByAddress[address(this)] = registryNftId;
|
396
|
-
_registryNftId = registryNftId;
|
397
475
|
|
476
|
+
_nftIdByAddress[address(this)] = registryNftId;
|
398
477
|
_chainNft.mint(NFT_LOCK_ADDRESS, registryId);
|
399
478
|
}
|
400
479
|
|
@@ -403,11 +482,11 @@ contract Registry is
|
|
403
482
|
private
|
404
483
|
{
|
405
484
|
uint256 globalRegistryId = _chainNft.GLOBAL_REGISTRY_ID();
|
406
|
-
NftId globalRegistryNftId = toNftId(globalRegistryId);
|
485
|
+
NftId globalRegistryNftId = NftIdLib.toNftId(globalRegistryId);
|
407
486
|
|
408
487
|
_info[globalRegistryNftId] = ObjectInfo({
|
409
488
|
nftId: globalRegistryNftId,
|
410
|
-
parentNftId: toNftId(_chainNft.PROTOCOL_NFT_ID()),
|
489
|
+
parentNftId: NftIdLib.toNftId(_chainNft.PROTOCOL_NFT_ID()),
|
411
490
|
objectType: REGISTRY(),
|
412
491
|
isInterceptor: false,
|
413
492
|
objectAddress: address(0),
|
@@ -417,6 +496,29 @@ contract Registry is
|
|
417
496
|
|
418
497
|
_chainNft.mint(NFT_LOCK_ADDRESS, globalRegistryId);
|
419
498
|
}
|
499
|
+
// depends on _registryNftId and _stakingAddress
|
500
|
+
function _registerStaking()
|
501
|
+
private
|
502
|
+
returns (NftId stakingNftId)
|
503
|
+
{
|
504
|
+
address stakingOwner = IRegisterable(_stakingAddress).getOwner();
|
505
|
+
uint256 stakingId = _chainNft.calculateTokenId(STAKING_TOKEN_SEQUENCE_ID);
|
506
|
+
stakingNftId = NftIdLib.toNftId(stakingId);
|
507
|
+
|
508
|
+
_info[stakingNftId] = ObjectInfo({
|
509
|
+
nftId: stakingNftId,
|
510
|
+
parentNftId: _registryNftId,
|
511
|
+
objectType: STAKING(),
|
512
|
+
isInterceptor: false,
|
513
|
+
objectAddress: _stakingAddress,
|
514
|
+
initialOwner: stakingOwner,
|
515
|
+
data: ""
|
516
|
+
});
|
517
|
+
|
518
|
+
_nftIdByAddress[_stakingAddress] = stakingNftId;
|
519
|
+
// reverts if nftId was already minted
|
520
|
+
_chainNft.mint(stakingOwner, stakingId);
|
521
|
+
}
|
420
522
|
|
421
523
|
/// @dev defines which object - parent types relations are allowed to register
|
422
524
|
// IMPORTANT:
|
@@ -434,31 +536,41 @@ contract Registry is
|
|
434
536
|
_coreTypes[PRODUCT()] = true;
|
435
537
|
_coreTypes[POOL()] = true;
|
436
538
|
_coreTypes[DISTRIBUTION()] = true;
|
539
|
+
_coreTypes[DISTRIBUTOR()] = true;
|
540
|
+
_coreTypes[ORACLE()] = true;
|
437
541
|
_coreTypes[POLICY()] = true;
|
438
542
|
_coreTypes[BUNDLE()] = true;
|
543
|
+
_coreTypes[STAKING()] = true;
|
439
544
|
_coreTypes[STAKE()] = true;
|
440
|
-
|
441
|
-
|
442
|
-
|
545
|
+
|
546
|
+
uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
|
547
|
+
if(registryId == _chainNft.GLOBAL_REGISTRY_ID()) {
|
548
|
+
// we are global registry
|
549
|
+
// object is registry from different chain
|
550
|
+
// parent is global registry, this contract
|
551
|
+
_coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
|
552
|
+
//_coreObjectCombinations[REGISTRY()][REGISTRY()] = true;
|
553
|
+
} else {
|
554
|
+
// we are not global registry
|
555
|
+
// object is local registry, this contract
|
556
|
+
// parent is global registry, object with 0 address or registry from mainnet???
|
557
|
+
}
|
558
|
+
_coreContractCombinations[STAKING()][REGISTRY()] = true; // only for chain staking contract
|
443
559
|
_coreContractCombinations[TOKEN()][REGISTRY()] = true;
|
444
560
|
//_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
|
445
|
-
|
446
|
-
// registry as parent, ONLY approved
|
447
561
|
_coreContractCombinations[INSTANCE()][REGISTRY()] = true;
|
448
562
|
|
449
|
-
// instance as parent, ONLY approved
|
450
563
|
_coreContractCombinations[PRODUCT()][INSTANCE()] = true;
|
451
564
|
_coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
|
452
565
|
_coreContractCombinations[ORACLE()][INSTANCE()] = true;
|
453
566
|
_coreContractCombinations[POOL()][INSTANCE()] = true;
|
454
567
|
|
455
568
|
_coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
|
456
|
-
|
457
|
-
// product as parent, ONLY approved
|
458
569
|
_coreObjectCombinations[POLICY()][PRODUCT()] = true;
|
459
|
-
|
460
|
-
// pool as parent, ONLY approved
|
461
570
|
_coreObjectCombinations[BUNDLE()][POOL()] = true;
|
462
|
-
|
571
|
+
|
572
|
+
// staking
|
573
|
+
_coreObjectCombinations[STAKE()][PROTOCOL()] = true;
|
574
|
+
_coreObjectCombinations[STAKE()][INSTANCE()] = true;
|
463
575
|
}
|
464
576
|
}
|