@etherisc/gif-next 0.0.2-c00cf5d-513 → 0.0.2-c0457ac-280
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/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +198 -177
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +130 -335
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +67 -96
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +83 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +35 -48
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +32 -101
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +65 -66
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +163 -10
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +81 -93
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +56 -40
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +84 -44
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +458 -331
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +268 -46
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +74 -43
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1095 -344
- 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 +1 -1
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +0 -53
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -71
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- 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/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +675 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1034 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +730 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +91 -264
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +56 -69
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +19 -51
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +145 -86
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +134 -133
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +242 -103
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +180 -376
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +42 -83
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +93 -167
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +56 -45
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +121 -211
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +64 -61
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +20 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +20 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +94 -25
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +40 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +241 -107
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +13 -55
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +180 -297
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +54 -99
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +163 -174
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +81 -54
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +337 -157
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +47 -230
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +34 -47
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +65 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +153 -1
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/IServiceAuthorization.sol/IServiceAuthorization.json +129 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +294 -15
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +1712 -103
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +198 -28
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +45 -42
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +321 -161
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorization.sol/ServiceAuthorization.json +171 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +187 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -136
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessAdmin.sol/AccessAdmin.json +1559 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +42 -10
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +52 -20
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +52 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +100 -96
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +916 -55
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +796 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +539 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessAdmin.sol/IAccessAdmin.json +1189 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +1 -1
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +76 -81
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +880 -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 +1 -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 +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +20 -1
- 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 +33 -20
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +19 -32
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +17 -22
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +16 -16
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +40 -4
- 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 +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +566 -54
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +460 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2005 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +761 -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 +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +657 -100
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +65 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2261 -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 +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +34 -34
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +96 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +4 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +114 -4
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +129 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +132 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +29 -53
- package/contracts/distribution/DistributionService.sol +61 -115
- package/contracts/distribution/IDistributionComponent.sol +5 -10
- package/contracts/distribution/IDistributionService.sol +2 -8
- package/contracts/instance/IInstance.sol +15 -7
- package/contracts/instance/IInstanceService.sol +35 -10
- package/contracts/instance/Instance.sol +63 -34
- package/contracts/instance/InstanceAdmin.sol +3 -2
- package/contracts/instance/InstanceAuthorizationsLib.sol +84 -27
- package/contracts/instance/InstanceReader.sol +64 -40
- package/contracts/instance/InstanceService.sol +185 -45
- package/contracts/instance/InstanceStore.sol +122 -64
- package/contracts/instance/base/BalanceStore.sol +123 -0
- package/contracts/instance/base/Cloneable.sol +2 -25
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/base/ObjectManager.sol +1 -3
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +15 -4
- package/contracts/instance/module/IPolicy.sol +8 -2
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +278 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +79 -167
- package/contracts/pool/IBundleService.sol +4 -16
- package/contracts/pool/IPoolComponent.sol +4 -6
- package/contracts/pool/IPoolService.sol +45 -9
- package/contracts/pool/Pool.sol +39 -42
- package/contracts/pool/PoolService.sol +190 -142
- package/contracts/product/ApplicationService.sol +109 -42
- package/contracts/product/ClaimService.sol +18 -19
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +6 -8
- package/contracts/product/IPricingService.sol +3 -1
- package/contracts/product/IProductComponent.sol +7 -6
- package/contracts/product/IProductService.sol +1 -8
- package/contracts/product/PolicyService.sol +225 -128
- package/contracts/product/PricingService.sol +72 -48
- package/contracts/product/Product.sol +47 -49
- package/contracts/product/ProductService.sol +26 -114
- package/contracts/registry/ChainNft.sol +8 -1
- package/contracts/registry/IRegistry.sol +15 -4
- package/contracts/registry/IRegistryService.sol +10 -0
- package/contracts/registry/IServiceAuthorization.sol +35 -0
- package/contracts/registry/Registry.sol +164 -47
- package/contracts/registry/RegistryAdmin.sol +264 -72
- package/contracts/registry/RegistryService.sol +48 -14
- package/contracts/registry/RegistryServiceManager.sol +2 -9
- package/contracts/registry/ReleaseManager.sol +242 -177
- package/contracts/registry/ServiceAuthorization.sol +86 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +200 -0
- package/contracts/registry/TokenRegistry.sol +261 -64
- package/contracts/shared/AccessAdmin.sol +759 -0
- package/contracts/shared/AccessManagerCustom.sol +6 -1
- package/contracts/shared/AccessManagerExtended.sol +19 -7
- package/contracts/shared/Component.sol +139 -129
- package/contracts/shared/ComponentService.sol +563 -88
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessAdmin.sol +168 -0
- package/contracts/shared/IComponent.sol +17 -37
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +6 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +8 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +144 -0
- package/contracts/{instance/base → shared}/KeyValueStore.sol +30 -72
- package/contracts/{instance/base → shared}/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +3 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +2 -3
- package/contracts/shared/Registerable.sol +2 -2
- package/contracts/shared/Service.sol +32 -21
- package/contracts/shared/TokenHandler.sol +24 -1
- package/contracts/staking/IStaking.sol +168 -0
- package/contracts/staking/IStakingService.sol +98 -47
- package/contracts/staking/StakeManagerLib.sol +231 -0
- package/contracts/staking/Staking.sol +513 -0
- package/contracts/staking/StakingManager.sol +54 -0
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +286 -44
- package/contracts/staking/StakingServiceManager.sol +7 -3
- package/contracts/staking/StakingStore.sol +613 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +20 -1
- package/contracts/type/Blocknumber.sol +20 -3
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/NftId.sol +14 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +142 -63
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +82 -20
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/Selector.sol +102 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/String.sol +53 -0
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- 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 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- 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/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
@@ -15,6 +15,7 @@ contract ChainNft is ERC721Enumerable {
|
|
15
15
|
uint256 public constant PROTOCOL_NFT_ID = 1101;
|
16
16
|
uint256 public constant GLOBAL_REGISTRY_ID = 2101;
|
17
17
|
|
18
|
+
// TODO rename errors to error pattern: CallerNotRegistry -> ErrorCallerNotRegistry etc.
|
18
19
|
// custom errors
|
19
20
|
error CallerNotRegistry(address caller);
|
20
21
|
error RegistryAddressZero();
|
@@ -59,7 +60,13 @@ contract ChainNft is ERC721Enumerable {
|
|
59
60
|
}
|
60
61
|
|
61
62
|
_chainIdMultiplier = 10 ** _chainIdDigits;
|
62
|
-
|
63
|
+
|
64
|
+
// the first object registered through normal registration starts with id 4
|
65
|
+
// 1 -> protocol
|
66
|
+
// 2 -> registry
|
67
|
+
// 3 -> staking
|
68
|
+
// >= 4 -> all other objects
|
69
|
+
_idNext = 4;
|
63
70
|
}
|
64
71
|
|
65
72
|
/**
|
@@ -76,8 +76,6 @@ interface IRegistry is IERC165 {
|
|
76
76
|
|
77
77
|
function getObjectCount() external view returns (uint256);
|
78
78
|
|
79
|
-
function getNftId() external view returns (NftId nftId);
|
80
|
-
|
81
79
|
function getNftId(address objectAddress) external view returns (NftId nftId);
|
82
80
|
|
83
81
|
function ownerOf(NftId nftId) external view returns (address);
|
@@ -103,11 +101,24 @@ interface IRegistry is IERC165 {
|
|
103
101
|
VersionPart releaseVersion
|
104
102
|
) external view returns (address serviceAddress);
|
105
103
|
|
104
|
+
function getProtocolNftId() external view returns (NftId protocolNftId);
|
105
|
+
|
106
|
+
function getNftId() external view returns (NftId nftId);
|
107
|
+
|
108
|
+
function getOwner() external view returns (address);
|
109
|
+
|
110
|
+
// TODO refactor the address getters below to contract getters
|
111
|
+
function getChainNftAddress() external view returns (address);
|
112
|
+
|
106
113
|
function getReleaseManagerAddress() external view returns (address);
|
107
114
|
|
108
115
|
function getReleaseAccessManagerAddress(VersionPart version) external view returns (address);
|
109
116
|
|
110
|
-
function
|
117
|
+
function getStakingAddress() external view returns (address);
|
111
118
|
|
112
|
-
function
|
119
|
+
function getTokenRegistryAddress() external view returns (address);
|
120
|
+
|
121
|
+
function getRegistryAdminAddress() external view returns (address);
|
122
|
+
|
123
|
+
function getAuthority() external view returns (address);
|
113
124
|
}
|
@@ -11,6 +11,8 @@ import {IRegistry} from "./IRegistry.sol";
|
|
11
11
|
|
12
12
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
13
13
|
import {IComponent} from "../shared/IComponent.sol";
|
14
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
15
|
+
|
14
16
|
|
15
17
|
interface IRegistryService is
|
16
18
|
IService
|
@@ -19,6 +21,7 @@ interface IRegistryService is
|
|
19
21
|
|
20
22
|
error ErrorRegistryServiceNotService(address notService);
|
21
23
|
error ErrorRegistryServiceNotInstance(address notInstance);
|
24
|
+
error ErrorRegistryServiceNotComponent(address notComponent);
|
22
25
|
error ErrorRegistryServiceNotProduct(address notProduct);
|
23
26
|
error ErrorRegistryServiceNotPool(address notPool);
|
24
27
|
error ErrorRegistryServiceNotDistribution(address notDistribution);
|
@@ -38,9 +41,15 @@ interface IRegistryService is
|
|
38
41
|
error ErrorRegistryServiceInvalidInitialOwner(address initialOwner);
|
39
42
|
error ErrorRegistryServiceInvalidAddress(address registerableAddress);
|
40
43
|
|
44
|
+
function registerStake(IRegistry.ObjectInfo memory info)
|
45
|
+
external returns(NftId nftId);
|
46
|
+
|
41
47
|
function registerInstance(IRegisterable instance, address owner)
|
42
48
|
external returns(IRegistry.ObjectInfo memory info);
|
43
49
|
|
50
|
+
function registerComponent(IComponent component, ObjectType objectType, address owner)
|
51
|
+
external returns(IRegistry.ObjectInfo memory info);
|
52
|
+
|
44
53
|
function registerProduct(IComponent product, address owner)
|
45
54
|
external returns(IRegistry.ObjectInfo memory info);
|
46
55
|
|
@@ -55,5 +64,6 @@ interface IRegistryService is
|
|
55
64
|
function registerPolicy(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
|
56
65
|
|
57
66
|
function registerBundle(IRegistry.ObjectInfo memory info) external returns(NftId nftId);
|
67
|
+
|
58
68
|
}
|
59
69
|
|
@@ -0,0 +1,35 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IAccessAdmin} from "../shared/IAccessAdmin.sol";
|
5
|
+
import {ObjectType} from "../../contracts/type/ObjectType.sol";
|
6
|
+
import {VersionPart} from "../../contracts/type/Version.sol";
|
7
|
+
|
8
|
+
interface IServiceAuthorization {
|
9
|
+
|
10
|
+
/// @dev Returns the commit hash representing the deployed release
|
11
|
+
function getCommitHash()
|
12
|
+
external
|
13
|
+
view
|
14
|
+
returns(string memory commitHash);
|
15
|
+
|
16
|
+
/// @dev Returns the release (VersionPart) for which the service authorizations are defined by this contract.
|
17
|
+
function getRelease()
|
18
|
+
external
|
19
|
+
view
|
20
|
+
returns(VersionPart release, uint domainsCount);
|
21
|
+
|
22
|
+
/// @dev Returns the full list of service domains for this release.
|
23
|
+
/// Services need to be registered for the release in revers order of this list.
|
24
|
+
function getServiceDomains() external view returns(ObjectType[] memory serviceDomains);
|
25
|
+
|
26
|
+
/// @dev Returns the expected service address for the provided domain.
|
27
|
+
function getServiceAddress(ObjectType serviceDomain) external view returns(address service);
|
28
|
+
|
29
|
+
/// @dev Given the service domain this function returns the list of other service domains that are authorized to access this service.
|
30
|
+
function getAuthorizedDomains(ObjectType serviceDomain) external view returns(ObjectType[] memory authorizatedDomains);
|
31
|
+
|
32
|
+
/// @dev For the given service domain and authorized domain the function returns the list of authorized functions
|
33
|
+
function getAuthorizedFunctions(ObjectType serviceDomain, ObjectType authorizedDomain) external view returns(IAccessAdmin.Function[] memory authorizatedFunctions);
|
34
|
+
}
|
35
|
+
|
@@ -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
|
+
import {InitializableCustom} from "../shared/InitializableCustom.sol";
|
8
|
+
|
9
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
7
10
|
import {VersionPart} from "../type/Version.sol";
|
8
|
-
import {ObjectType, PROTOCOL, REGISTRY, TOKEN, SERVICE, INSTANCE, STAKE, PRODUCT, DISTRIBUTION, DISTRIBUTOR, ORACLE, POOL, POLICY, BUNDLE} from "../type/ObjectType.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,11 +49,23 @@ 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
|
|
63
|
+
// TODO
|
64
|
+
// 1). Registry and ReleaseManager must be treated as whole single entity.
|
65
|
+
// But current limitations of EVM does not allow it -> require it to be splitted
|
66
|
+
// 2). Keep onlyReleaseManager modifier
|
67
|
+
// 3). Delete onlyRegistryService in favor of restricted, introduce aditional "domain role", REGISTRY_SERVICE_ROLE
|
68
|
+
// 4). (For GlobalRegistry ONLY) make registerChainRegistry() restricted to GIF_ADMIN_ROLE
|
49
69
|
modifier onlyRegistryService() {
|
50
70
|
if(!_releaseManager.isActiveRegistryService(msg.sender)) {
|
51
71
|
revert ErrorRegistryCallerNotRegistryService();
|
@@ -53,6 +73,7 @@ contract Registry is
|
|
53
73
|
_;
|
54
74
|
}
|
55
75
|
|
76
|
+
|
56
77
|
modifier onlyReleaseManager() {
|
57
78
|
if(msg.sender != address(_releaseManager)) {
|
58
79
|
revert ErrorRegistryCallerNotReleaseManager();
|
@@ -60,21 +81,40 @@ contract Registry is
|
|
60
81
|
_;
|
61
82
|
}
|
62
83
|
|
63
|
-
constructor()
|
64
|
-
{
|
65
|
-
_releaseManager = ReleaseManager(msg.sender);
|
66
84
|
|
85
|
+
constructor(RegistryAdmin admin)
|
86
|
+
InitializableCustom()
|
87
|
+
{
|
88
|
+
_admin = admin;
|
67
89
|
// deploy NFT
|
68
90
|
_chainNft = new ChainNft(address(this));
|
69
91
|
|
70
92
|
// initial registry setup
|
71
|
-
_registerProtocol();
|
72
|
-
_registerRegistry();
|
93
|
+
_protocolNftId = _registerProtocol();
|
94
|
+
_registryNftId = _registerRegistry();
|
73
95
|
|
74
96
|
// set object types and object parent relations
|
75
97
|
_setupValidCoreTypesAndCombinations();
|
76
98
|
}
|
77
99
|
|
100
|
+
|
101
|
+
/// @dev wires release manager and token to registry (this contract).
|
102
|
+
/// MUST be called by release manager.
|
103
|
+
function initialize(
|
104
|
+
address releaseManager,
|
105
|
+
address tokenRegistry,
|
106
|
+
address staking
|
107
|
+
)
|
108
|
+
external
|
109
|
+
initializer()
|
110
|
+
{
|
111
|
+
_releaseManager = ReleaseManager(releaseManager);
|
112
|
+
_tokenRegistryAddress = tokenRegistry;
|
113
|
+
_stakingAddress = staking;
|
114
|
+
|
115
|
+
_stakingNftId = _registerStaking();
|
116
|
+
}
|
117
|
+
|
78
118
|
function registerService(
|
79
119
|
ObjectInfo memory info,
|
80
120
|
VersionPart version,
|
@@ -194,6 +234,10 @@ contract Registry is
|
|
194
234
|
return _registryNftId;
|
195
235
|
}
|
196
236
|
|
237
|
+
function getProtocolNftId() external view returns (NftId nftId) {
|
238
|
+
return _protocolNftId;
|
239
|
+
}
|
240
|
+
|
197
241
|
function getNftId(address object) external view returns (NftId id) {
|
198
242
|
return _nftIdByAddress[object];
|
199
243
|
}
|
@@ -236,12 +280,22 @@ contract Registry is
|
|
236
280
|
return _releaseManager.isActiveRelease(version);
|
237
281
|
}
|
238
282
|
|
283
|
+
function getStakingAddress() external view returns (address staking) {
|
284
|
+
//return getObjectInfo(_stakingNftId).objectAddress;
|
285
|
+
//return _info[_stakingNftId].objectAddress;
|
286
|
+
return _stakingAddress;
|
287
|
+
}
|
288
|
+
|
289
|
+
function getTokenRegistryAddress() external view returns (address tokenRegistry) {
|
290
|
+
return _tokenRegistryAddress;
|
291
|
+
}
|
292
|
+
|
239
293
|
function getServiceAddress(
|
240
294
|
ObjectType serviceDomain,
|
241
295
|
VersionPart releaseVersion
|
242
296
|
) external view returns (address service)
|
243
297
|
{
|
244
|
-
|
298
|
+
service = _service[releaseVersion][serviceDomain];
|
245
299
|
}
|
246
300
|
|
247
301
|
function getReleaseAccessManagerAddress(VersionPart version) external view returns (address) {
|
@@ -256,6 +310,14 @@ contract Registry is
|
|
256
310
|
return address(_chainNft);
|
257
311
|
}
|
258
312
|
|
313
|
+
function getRegistryAdminAddress() external view returns (address) {
|
314
|
+
return address(_admin);
|
315
|
+
}
|
316
|
+
|
317
|
+
function getAuthority() external view returns (address) {
|
318
|
+
return _admin.authority();
|
319
|
+
}
|
320
|
+
|
259
321
|
function getOwner() public view returns (address owner) {
|
260
322
|
return ownerOf(address(this));
|
261
323
|
}
|
@@ -279,59 +341,76 @@ contract Registry is
|
|
279
341
|
returns(NftId nftId)
|
280
342
|
{
|
281
343
|
ObjectType objectType = info.objectType;
|
344
|
+
bool isInterceptor = info.isInterceptor;
|
345
|
+
address objectAddress = info.objectAddress;
|
346
|
+
address owner = info.initialOwner;
|
347
|
+
|
282
348
|
NftId parentNftId = info.parentNftId;
|
283
349
|
ObjectInfo memory parentInfo = _info[parentNftId];
|
284
350
|
ObjectType parentType = parentInfo.objectType; // see function header
|
285
351
|
address parentAddress = parentInfo.objectAddress;
|
286
352
|
|
287
353
|
// parent is contract -> need to check? -> check before minting
|
354
|
+
// special case: staking: to protocol possible as well
|
288
355
|
// special case: global registry nft as parent when not on mainnet -> global registry address is 0
|
289
356
|
// special case: when parentNftId == _chainNft.mint(), check for zero parent address before mint
|
290
357
|
// special case: when parentNftId == _chainNft.mint() && objectAddress == initialOwner
|
291
|
-
if(
|
292
|
-
|
358
|
+
if(objectType != STAKE()) {
|
359
|
+
if(parentAddress == address(0)) {
|
360
|
+
revert ErrorRegistryParentAddressZero();
|
361
|
+
}
|
293
362
|
}
|
294
363
|
|
295
|
-
address
|
296
|
-
|
297
|
-
|
364
|
+
address interceptorAddress = _getInterceptor(
|
365
|
+
isInterceptor,
|
366
|
+
objectType,
|
367
|
+
objectAddress,
|
368
|
+
parentInfo.isInterceptor,
|
369
|
+
parentAddress);
|
298
370
|
|
371
|
+
uint256 tokenId = _chainNft.getNextTokenId();
|
372
|
+
nftId = NftIdLib.toNftId(tokenId);
|
299
373
|
info.nftId = nftId;
|
300
374
|
_info[nftId] = info;
|
301
375
|
|
302
|
-
if(
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
if(_nftIdByAddress[contractAddress].gtz()) {
|
307
|
-
revert ErrorRegistryContractAlreadyRegistered(contractAddress);
|
376
|
+
if(objectAddress > address(0)) {
|
377
|
+
if(_nftIdByAddress[objectAddress].gtz()) {
|
378
|
+
revert ErrorRegistryContractAlreadyRegistered(objectAddress);
|
308
379
|
}
|
309
380
|
|
310
|
-
_nftIdByAddress[
|
381
|
+
_nftIdByAddress[objectAddress] = nftId;
|
311
382
|
}
|
312
383
|
|
313
|
-
emit LogRegistration(nftId, parentNftId, objectType,
|
384
|
+
emit LogRegistration(nftId, parentNftId, objectType, isInterceptor, objectAddress, owner);
|
314
385
|
|
315
386
|
// calls nft receiver(1) and interceptor(2)
|
316
387
|
uint256 mintedTokenId = _chainNft.mint(
|
317
|
-
|
318
|
-
|
388
|
+
owner,
|
389
|
+
interceptorAddress,
|
319
390
|
EMPTY_URI);
|
320
|
-
|
321
|
-
|
391
|
+
|
392
|
+
assert(mintedTokenId == tokenId);
|
322
393
|
}
|
323
394
|
|
324
395
|
/// @dev obtain interceptor address for this nft if applicable, address(0) otherwise
|
396
|
+
/// special case: STAKES (parent may be any type) -> no intercept call
|
397
|
+
/// default case:
|
325
398
|
function _getInterceptor(
|
326
399
|
bool isInterceptor,
|
400
|
+
ObjectType objectType,
|
327
401
|
address objectAddress,
|
328
402
|
bool parentIsInterceptor,
|
329
403
|
address parentObjectAddress
|
330
404
|
)
|
331
405
|
internal
|
332
|
-
|
406
|
+
pure
|
333
407
|
returns (address interceptor)
|
334
408
|
{
|
409
|
+
// no intercepting calls for stakes
|
410
|
+
if (objectType == STAKE()) {
|
411
|
+
return address(0);
|
412
|
+
}
|
413
|
+
|
335
414
|
if (objectAddress == address(0)) {
|
336
415
|
if (parentIsInterceptor) {
|
337
416
|
return parentObjectAddress;
|
@@ -352,13 +431,14 @@ contract Registry is
|
|
352
431
|
/// @dev protocol registration used to anchor the dip ecosystem relations
|
353
432
|
function _registerProtocol()
|
354
433
|
private
|
434
|
+
returns (NftId protocolNftId)
|
355
435
|
{
|
356
436
|
uint256 protocolId = _chainNft.PROTOCOL_NFT_ID();
|
357
|
-
|
437
|
+
protocolNftId = NftIdLib.toNftId(protocolId);
|
358
438
|
|
359
439
|
_info[protocolNftId] = ObjectInfo({
|
360
440
|
nftId: protocolNftId,
|
361
|
-
parentNftId:
|
441
|
+
parentNftId: NftIdLib.zero(),
|
362
442
|
objectType: PROTOCOL(),
|
363
443
|
isInterceptor: false,
|
364
444
|
objectAddress: address(0),
|
@@ -373,19 +453,20 @@ contract Registry is
|
|
373
453
|
/// might also register the global registry when not on mainnet
|
374
454
|
function _registerRegistry()
|
375
455
|
private
|
456
|
+
returns (NftId registryNftId)
|
376
457
|
{
|
377
458
|
uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
|
378
|
-
|
459
|
+
registryNftId = NftIdLib.toNftId(registryId);
|
379
460
|
NftId parentNftId;
|
380
461
|
|
381
462
|
if(registryId != _chainNft.GLOBAL_REGISTRY_ID())
|
382
463
|
{// we're not the global registry
|
383
464
|
_registerGlobalRegistry();
|
384
|
-
parentNftId = toNftId(_chainNft.GLOBAL_REGISTRY_ID());
|
465
|
+
parentNftId = NftIdLib.toNftId(_chainNft.GLOBAL_REGISTRY_ID());
|
385
466
|
}
|
386
467
|
else
|
387
468
|
{// we are global registry
|
388
|
-
parentNftId =
|
469
|
+
parentNftId = _protocolNftId;
|
389
470
|
}
|
390
471
|
|
391
472
|
_info[registryNftId] = ObjectInfo({
|
@@ -397,9 +478,8 @@ contract Registry is
|
|
397
478
|
initialOwner: NFT_LOCK_ADDRESS,
|
398
479
|
data: ""
|
399
480
|
});
|
400
|
-
_nftIdByAddress[address(this)] = registryNftId;
|
401
|
-
_registryNftId = registryNftId;
|
402
481
|
|
482
|
+
_nftIdByAddress[address(this)] = registryNftId;
|
403
483
|
_chainNft.mint(NFT_LOCK_ADDRESS, registryId);
|
404
484
|
}
|
405
485
|
|
@@ -408,11 +488,11 @@ contract Registry is
|
|
408
488
|
private
|
409
489
|
{
|
410
490
|
uint256 globalRegistryId = _chainNft.GLOBAL_REGISTRY_ID();
|
411
|
-
NftId globalRegistryNftId = toNftId(globalRegistryId);
|
491
|
+
NftId globalRegistryNftId = NftIdLib.toNftId(globalRegistryId);
|
412
492
|
|
413
493
|
_info[globalRegistryNftId] = ObjectInfo({
|
414
494
|
nftId: globalRegistryNftId,
|
415
|
-
parentNftId: toNftId(_chainNft.PROTOCOL_NFT_ID()),
|
495
|
+
parentNftId: NftIdLib.toNftId(_chainNft.PROTOCOL_NFT_ID()),
|
416
496
|
objectType: REGISTRY(),
|
417
497
|
isInterceptor: false,
|
418
498
|
objectAddress: address(0),
|
@@ -422,13 +502,36 @@ contract Registry is
|
|
422
502
|
|
423
503
|
_chainNft.mint(NFT_LOCK_ADDRESS, globalRegistryId);
|
424
504
|
}
|
505
|
+
// depends on _registryNftId and _stakingAddress
|
506
|
+
function _registerStaking()
|
507
|
+
private
|
508
|
+
returns (NftId stakingNftId)
|
509
|
+
{
|
510
|
+
address stakingOwner = IRegisterable(_stakingAddress).getOwner();
|
511
|
+
uint256 stakingId = _chainNft.calculateTokenId(STAKING_TOKEN_SEQUENCE_ID);
|
512
|
+
stakingNftId = NftIdLib.toNftId(stakingId);
|
513
|
+
|
514
|
+
_info[stakingNftId] = ObjectInfo({
|
515
|
+
nftId: stakingNftId,
|
516
|
+
parentNftId: _registryNftId,
|
517
|
+
objectType: STAKING(),
|
518
|
+
isInterceptor: false,
|
519
|
+
objectAddress: _stakingAddress,
|
520
|
+
initialOwner: stakingOwner,
|
521
|
+
data: ""
|
522
|
+
});
|
523
|
+
|
524
|
+
_nftIdByAddress[_stakingAddress] = stakingNftId;
|
525
|
+
// reverts if nftId was already minted
|
526
|
+
_chainNft.mint(stakingOwner, stakingId);
|
527
|
+
}
|
425
528
|
|
426
529
|
/// @dev defines which object - parent types relations are allowed to register
|
427
530
|
// IMPORTANT:
|
428
531
|
// 1) EACH object type MUST have only one parent type across ALL mappings
|
429
532
|
// 2) DO NOT use object type (e.g. POLCY, BUNDLE, STAKE) as parent type
|
430
533
|
// 3) DO NOT use REGISTRY as object type
|
431
|
-
// 2) DO NOT use PROTOCOL and "
|
534
|
+
// 2) DO NOT use PROTOCOL and "ObjectTypeLib.zero"
|
432
535
|
function _setupValidCoreTypesAndCombinations()
|
433
536
|
private
|
434
537
|
{
|
@@ -443,23 +546,37 @@ contract Registry is
|
|
443
546
|
_coreTypes[ORACLE()] = true;
|
444
547
|
_coreTypes[POLICY()] = true;
|
445
548
|
_coreTypes[BUNDLE()] = true;
|
549
|
+
_coreTypes[STAKING()] = true;
|
446
550
|
_coreTypes[STAKE()] = true;
|
447
551
|
|
552
|
+
uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
|
553
|
+
if(registryId == _chainNft.GLOBAL_REGISTRY_ID()) {
|
554
|
+
// we are global registry
|
555
|
+
// object is registry from different chain
|
556
|
+
// parent is global registry, this contract
|
557
|
+
_coreContractCombinations[REGISTRY()][REGISTRY()] = true; // only for global regstry
|
558
|
+
//_coreObjectCombinations[REGISTRY()][REGISTRY()] = true;
|
559
|
+
} else {
|
560
|
+
// we are not global registry
|
561
|
+
// object is local registry, this contract
|
562
|
+
// parent is global registry, object with 0 address or registry from mainnet???
|
563
|
+
}
|
564
|
+
_coreContractCombinations[STAKING()][REGISTRY()] = true; // only for chain staking contract
|
565
|
+
_coreContractCombinations[TOKEN()][REGISTRY()] = true;
|
566
|
+
//_coreContractCombinations[SERVICE()][REGISTRY()] = true;// do not need it here -> registerService() registers exactly this combination
|
448
567
|
_coreContractCombinations[INSTANCE()][REGISTRY()] = true;
|
568
|
+
|
449
569
|
_coreContractCombinations[PRODUCT()][INSTANCE()] = true;
|
450
570
|
_coreContractCombinations[DISTRIBUTION()][INSTANCE()] = true;
|
451
571
|
_coreContractCombinations[ORACLE()][INSTANCE()] = true;
|
452
572
|
_coreContractCombinations[POOL()][INSTANCE()] = true;
|
453
573
|
|
454
|
-
uint256 registryId = _chainNft.calculateTokenId(REGISTRY_TOKEN_SEQUENCE_ID);
|
455
|
-
if(registryId == _chainNft.GLOBAL_REGISTRY_ID())
|
456
|
-
{// we are global registry
|
457
|
-
_coreObjectCombinations[REGISTRY()][REGISTRY()] = true;
|
458
|
-
}
|
459
|
-
|
460
574
|
_coreObjectCombinations[DISTRIBUTOR()][DISTRIBUTION()] = true;
|
461
575
|
_coreObjectCombinations[POLICY()][PRODUCT()] = true;
|
462
576
|
_coreObjectCombinations[BUNDLE()][POOL()] = true;
|
463
|
-
|
577
|
+
|
578
|
+
// staking
|
579
|
+
_coreObjectCombinations[STAKE()][PROTOCOL()] = true;
|
580
|
+
_coreObjectCombinations[STAKE()][INSTANCE()] = true;
|
464
581
|
}
|
465
582
|
}
|