@etherisc/gif-next 0.0.2-fca9315-260 → 0.0.2-fd4931b-974
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 -13
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1410 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1343 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +799 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Pool.sol/Pool.json → distribution/IDistributionComponent.sol/IDistributionComponent.json} +366 -367
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +808 -0
- 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 +267 -1594
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +285 -211
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +412 -2526
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +480 -166
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +132 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +610 -421
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +438 -399
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +348 -106
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3468 -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 +58 -75
- 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 +1091 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +723 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +257 -288
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +565 -186
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1044 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1559 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1411 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +719 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +820 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +699 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1264 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +787 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IPoolService.sol/IPoolService.json → product/IApplicationService.sol/IApplicationService.json} +211 -212
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IPolicyService.sol/IPolicyService.json +237 -302
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +530 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Product.sol/Product.json → product/IProductComponent.sol/IProductComponent.json} +351 -311
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IDistributionService.sol/IDistributionService.json → product/IProductService.sol/IProductService.json} +112 -172
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1132 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +731 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +969 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +755 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/{components/IProductComponent.sol/IProductComponent.json → product/Product.sol/Product.json} +857 -214
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +673 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +675 -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 +158 -13
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +337 -225
- 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 +277 -30
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +74 -61
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +465 -267
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +334 -93
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +634 -69
- 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 +448 -50
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components/Distribution.sol/Distribution.json → shared/Component.sol/Component.json} +321 -280
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1461 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +765 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IProductService.sol/IProductService.json → shared/ComponentVerifyingService.sol/ComponentVerifyingService.json} +215 -226
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/IDistributionComponent.sol/IDistributionComponent.json → shared/IComponent.sol/IComponent.json} +205 -228
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +854 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/{components/Component.sol/Component.json → shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json} +203 -160
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +50 -1
- 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 +27 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +207 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -29
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IA.sol/ISharedA.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +15 -17
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +71 -160
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +1030 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +581 -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 +314 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +102 -35
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +320 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +310 -74
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +125 -60
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +172 -160
- 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/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1770 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base/ComponentService.sol/ComponentService.json → staking/IStakingService.sol/IStakingService.json} +261 -238
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +2500 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +844 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +263 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +960 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +694 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +308 -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 +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Blocknumber.sol/BlocknumberLib.json +16 -3
- 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 +185 -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 +148 -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/distribution/Distribution.sol +263 -0
- package/contracts/distribution/DistributionService.sol +298 -0
- package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +15 -12
- package/contracts/distribution/IDistributionComponent.sol +66 -0
- package/contracts/distribution/IDistributionService.sol +81 -0
- package/contracts/instance/BundleManager.sol +15 -14
- package/contracts/instance/IInstance.sol +49 -44
- package/contracts/instance/IInstanceService.sol +57 -15
- package/contracts/instance/Instance.sol +138 -179
- package/contracts/instance/InstanceAccessManager.sol +406 -161
- package/contracts/instance/InstanceAuthorizationsLib.sol +336 -0
- package/contracts/instance/InstanceReader.sol +135 -62
- package/contracts/instance/InstanceService.sol +240 -305
- package/contracts/instance/InstanceServiceManager.sol +12 -22
- 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 +24 -18
- package/contracts/instance/module/IBundle.sol +8 -8
- package/contracts/instance/module/IComponents.sol +52 -0
- package/contracts/instance/module/IDistribution.sol +7 -4
- package/contracts/instance/module/IPolicy.sol +56 -17
- 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 +147 -0
- package/contracts/pool/Pool.sol +299 -0
- package/contracts/pool/PoolService.sol +424 -0
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +254 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/ClaimService.sol +437 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +78 -0
- 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 +473 -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 +15 -1
- package/contracts/registry/IRegistry.sol +38 -18
- package/contracts/registry/IRegistryService.sol +41 -38
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +193 -82
- package/contracts/registry/RegistryAccessManager.sol +72 -121
- package/contracts/registry/RegistryService.sol +164 -98
- package/contracts/registry/RegistryServiceManager.sol +28 -18
- package/contracts/registry/ReleaseManager.sol +390 -192
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +263 -56
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/Component.sol +286 -0
- package/contracts/shared/ComponentService.sol +595 -0
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +111 -0
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/IComponent.sol +74 -0
- package/contracts/shared/IComponentService.sol +91 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +46 -0
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +14 -10
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +12 -11
- package/contracts/shared/IPolicyHolder.sol +45 -0
- package/contracts/shared/IRegisterable.sol +3 -3
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +5 -48
- package/contracts/shared/InstanceLinkedComponent.sol +145 -0
- package/contracts/shared/KeyValueStore.sol +130 -0
- package/contracts/{instance/base → shared}/Lifecycle.sol +28 -7
- package/contracts/shared/NftIdSetManager.sol +69 -0
- package/contracts/shared/NftOwnable.sol +64 -85
- package/contracts/shared/PolicyHolder.sol +101 -0
- package/contracts/shared/ProxyManager.sol +126 -25
- package/contracts/shared/Registerable.sol +19 -30
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +37 -20
- package/contracts/shared/TokenHandler.sol +37 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/staking/IStaking.sol +113 -0
- package/contracts/staking/IStakingService.sol +122 -0
- package/contracts/staking/Staking.sol +348 -0
- package/contracts/staking/StakingManager.sol +52 -0
- package/contracts/staking/StakingReader.sol +92 -0
- package/contracts/staking/StakingService.sol +294 -0
- package/contracts/staking/StakingServiceManager.sol +44 -0
- package/contracts/staking/TargetManagerLib.sol +141 -0
- package/contracts/type/Amount.sol +114 -0
- package/contracts/{types → type}/Blocknumber.sol +7 -1
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/{types → type}/DistributorType.sol +2 -2
- package/contracts/{types → type}/Fee.sol +32 -22
- package/contracts/{types → type}/NftId.sol +17 -11
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +26 -9
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/{types → type}/Referral.sol +4 -0
- package/contracts/type/RoleId.sol +143 -0
- package/contracts/type/Seconds.sol +63 -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 +1 -0
- 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/IComponent.sol/IComponent.json +0 -455
- 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/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +0 -4
- 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/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1102
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -449
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -772
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -437
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- 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/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 -1227
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -505
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -806
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -437
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -856
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -437
- 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 -313
- 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 -608
- 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 -286
- 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/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- 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/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 -216
- package/contracts/components/Distribution.sol +0 -150
- package/contracts/components/IComponent.sol +0 -43
- package/contracts/components/IDistributionComponent.sol +0 -47
- package/contracts/components/IPoolComponent.sol +0 -60
- package/contracts/components/IProductComponent.sol +0 -39
- package/contracts/components/Pool.sol +0 -227
- package/contracts/components/Product.sol +0 -265
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/base/ComponentService.sol +0 -134
- package/contracts/instance/base/KeyValueStore.sol +0 -172
- package/contracts/instance/module/ISetup.sol +0 -46
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/instance/service/BundleService.sol +0 -293
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/DistributionService.sol +0 -106
- package/contracts/instance/service/IBundleService.sol +0 -44
- package/contracts/instance/service/IDistributionService.sol +0 -12
- package/contracts/instance/service/IPolicyService.sol +0 -94
- package/contracts/instance/service/IPoolService.sol +0 -20
- package/contracts/instance/service/IProductService.sol +0 -40
- package/contracts/instance/service/PolicyService.sol +0 -538
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolService.sol +0 -110
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- package/contracts/instance/service/ProductService.sol +0 -234
- package/contracts/instance/service/ProductServiceManager.sol +0 -54
- 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/RoleId.sol +0 -90
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
@@ -0,0 +1,377 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
6
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
7
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
8
|
+
import {InstanceLinkedComponent} from "../shared/InstanceLinkedComponent.sol";
|
9
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
10
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
11
|
+
import {IApplicationService} from "./IApplicationService.sol";
|
12
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
13
|
+
import {IPolicyService} from "./IPolicyService.sol";
|
14
|
+
import {IProductService} from "./IProductService.sol";
|
15
|
+
import {IClaimService} from "./IClaimService.sol";
|
16
|
+
import {IPricingService} from "./IPricingService.sol";
|
17
|
+
import {IProductComponent} from "./IProductComponent.sol";
|
18
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
19
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
20
|
+
import {COMPONENT, PRODUCT, APPLICATION, POLICY, CLAIM, PRICE } from "../type/ObjectType.sol";
|
21
|
+
import {ReferralId} from "../type/Referral.sol";
|
22
|
+
import {RiskId, RiskIdLib} from "../type/RiskId.sol";
|
23
|
+
import {Seconds} from "../type/Seconds.sol";
|
24
|
+
import {StateId} from "../type/StateId.sol";
|
25
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
26
|
+
|
27
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
28
|
+
|
29
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
30
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
31
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
32
|
+
import {Pool} from "../pool/Pool.sol";
|
33
|
+
import {Distribution} from "../distribution/Distribution.sol";
|
34
|
+
|
35
|
+
abstract contract Product is
|
36
|
+
InstanceLinkedComponent,
|
37
|
+
IProductComponent
|
38
|
+
{
|
39
|
+
// keccak256(abi.encode(uint256(keccak256("etherisc.storage.Product")) - 1)) & ~bytes32(uint256(0xff));
|
40
|
+
bytes32 public constant PRODUCT_STORAGE_LOCATION_V1 = 0x0bb7aafdb8e380f81267337bc5b5dfdf76e6d3a380ecadb51ec665246d9d6800;
|
41
|
+
|
42
|
+
struct ProductStorage {
|
43
|
+
IProductService _productService;
|
44
|
+
IApplicationService _applicationService;
|
45
|
+
IPolicyService _policyService;
|
46
|
+
IClaimService _claimService;
|
47
|
+
IPricingService _pricingService;
|
48
|
+
IComponentService _componentService;
|
49
|
+
NftId _poolNftId;
|
50
|
+
NftId _distributionNftId;
|
51
|
+
Pool _pool;
|
52
|
+
Distribution _distribution;
|
53
|
+
}
|
54
|
+
|
55
|
+
function initializeProduct(
|
56
|
+
address registry,
|
57
|
+
NftId instanceNftId,
|
58
|
+
address initialOwner,
|
59
|
+
string memory name,
|
60
|
+
address token,
|
61
|
+
bool isInterceptor,
|
62
|
+
address pool,
|
63
|
+
address distribution,
|
64
|
+
bytes memory registryData, // writeonly data that will saved in the object info record of the registry
|
65
|
+
bytes memory componentData // writeonly data that will saved in the object info record of the registry
|
66
|
+
)
|
67
|
+
public
|
68
|
+
virtual
|
69
|
+
onlyInitializing()
|
70
|
+
{
|
71
|
+
initializeInstanceLinkedComponent(registry, instanceNftId, name, token, PRODUCT(), isInterceptor, initialOwner, registryData, componentData);
|
72
|
+
|
73
|
+
ProductStorage storage $ = _getProductStorage();
|
74
|
+
// TODO add validation
|
75
|
+
// TODO refactor to go via registry ?
|
76
|
+
$._productService = IProductService(_getServiceAddress(PRODUCT()));
|
77
|
+
$._applicationService = IApplicationService(_getServiceAddress(APPLICATION()));
|
78
|
+
$._policyService = IPolicyService(_getServiceAddress(POLICY()));
|
79
|
+
$._claimService = IClaimService(_getServiceAddress(CLAIM()));
|
80
|
+
$._pricingService = IPricingService(_getServiceAddress(PRICE()));
|
81
|
+
$._componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
82
|
+
$._pool = Pool(pool);
|
83
|
+
$._distribution = Distribution(distribution);
|
84
|
+
$._poolNftId = getRegistry().getNftId(pool);
|
85
|
+
$._distributionNftId = getRegistry().getNftId(distribution);
|
86
|
+
|
87
|
+
registerInterface(type(IProductComponent).interfaceId);
|
88
|
+
}
|
89
|
+
|
90
|
+
|
91
|
+
function register()
|
92
|
+
external
|
93
|
+
virtual
|
94
|
+
onlyOwner()
|
95
|
+
{
|
96
|
+
_getProductStorage()._componentService.registerProduct();
|
97
|
+
}
|
98
|
+
|
99
|
+
|
100
|
+
function setFees(
|
101
|
+
Fee memory productFee,
|
102
|
+
Fee memory processingFee
|
103
|
+
)
|
104
|
+
external
|
105
|
+
onlyOwner
|
106
|
+
restricted()
|
107
|
+
override
|
108
|
+
{
|
109
|
+
_getProductStorage()._componentService.setProductFees(productFee, processingFee);
|
110
|
+
}
|
111
|
+
|
112
|
+
function _createRisk(
|
113
|
+
RiskId id,
|
114
|
+
bytes memory data
|
115
|
+
) internal {
|
116
|
+
_getProductService().createRisk(
|
117
|
+
id,
|
118
|
+
data
|
119
|
+
);
|
120
|
+
}
|
121
|
+
|
122
|
+
function _updateRisk(
|
123
|
+
RiskId id,
|
124
|
+
bytes memory data
|
125
|
+
) internal {
|
126
|
+
_getProductService().updateRisk(
|
127
|
+
id,
|
128
|
+
data
|
129
|
+
);
|
130
|
+
}
|
131
|
+
|
132
|
+
function _updateRiskState(
|
133
|
+
RiskId id,
|
134
|
+
StateId state
|
135
|
+
) internal {
|
136
|
+
_getProductService().updateRiskState(
|
137
|
+
id,
|
138
|
+
state
|
139
|
+
);
|
140
|
+
}
|
141
|
+
|
142
|
+
function _getRiskInfo(RiskId id) internal view returns (IRisk.RiskInfo memory info) {
|
143
|
+
return getInstance().getInstanceReader().getRiskInfo(id);
|
144
|
+
}
|
145
|
+
|
146
|
+
function _createApplication(
|
147
|
+
address applicationOwner,
|
148
|
+
RiskId riskId,
|
149
|
+
Amount sumInsuredAmount,
|
150
|
+
Seconds lifetime,
|
151
|
+
NftId bundleNftId,
|
152
|
+
ReferralId referralId,
|
153
|
+
bytes memory applicationData
|
154
|
+
)
|
155
|
+
internal
|
156
|
+
returns (NftId applicationNftId)
|
157
|
+
{
|
158
|
+
return _getProductStorage()._applicationService.create(
|
159
|
+
applicationOwner,
|
160
|
+
riskId,
|
161
|
+
sumInsuredAmount,
|
162
|
+
lifetime,
|
163
|
+
bundleNftId,
|
164
|
+
referralId,
|
165
|
+
applicationData
|
166
|
+
);
|
167
|
+
}
|
168
|
+
|
169
|
+
function _collateralize(
|
170
|
+
NftId policyNftId,
|
171
|
+
bool requirePremiumPayment,
|
172
|
+
Timestamp activateAt
|
173
|
+
)
|
174
|
+
internal
|
175
|
+
{
|
176
|
+
_getProductStorage()._policyService.collateralize(
|
177
|
+
policyNftId,
|
178
|
+
requirePremiumPayment,
|
179
|
+
activateAt);
|
180
|
+
}
|
181
|
+
|
182
|
+
function _collectPremium(
|
183
|
+
NftId policyNftId,
|
184
|
+
Timestamp activateAt
|
185
|
+
)
|
186
|
+
internal
|
187
|
+
{
|
188
|
+
_getProductStorage()._policyService.collectPremium(
|
189
|
+
policyNftId,
|
190
|
+
activateAt);
|
191
|
+
}
|
192
|
+
|
193
|
+
function _activate(
|
194
|
+
NftId policyNftId,
|
195
|
+
Timestamp activateAt
|
196
|
+
)
|
197
|
+
internal
|
198
|
+
{
|
199
|
+
_getProductStorage()._policyService.activate(
|
200
|
+
policyNftId,
|
201
|
+
activateAt);
|
202
|
+
}
|
203
|
+
|
204
|
+
function _close(
|
205
|
+
NftId policyNftId
|
206
|
+
)
|
207
|
+
internal
|
208
|
+
{
|
209
|
+
_getProductStorage()._policyService.close(
|
210
|
+
policyNftId);
|
211
|
+
}
|
212
|
+
|
213
|
+
function _submitClaim(
|
214
|
+
NftId policyNftId,
|
215
|
+
Amount claimAmount,
|
216
|
+
bytes memory claimData
|
217
|
+
)
|
218
|
+
internal
|
219
|
+
returns(ClaimId)
|
220
|
+
{
|
221
|
+
return _getProductStorage()._claimService.submit(
|
222
|
+
policyNftId,
|
223
|
+
claimAmount,
|
224
|
+
claimData);
|
225
|
+
}
|
226
|
+
|
227
|
+
function _confirmClaim(
|
228
|
+
NftId policyNftId,
|
229
|
+
ClaimId claimId,
|
230
|
+
Amount confirmedAmount,
|
231
|
+
bytes memory data
|
232
|
+
)
|
233
|
+
internal
|
234
|
+
{
|
235
|
+
_getProductStorage()._claimService.confirm(
|
236
|
+
policyNftId,
|
237
|
+
claimId,
|
238
|
+
confirmedAmount,
|
239
|
+
data);
|
240
|
+
}
|
241
|
+
|
242
|
+
function _declineClaim(
|
243
|
+
NftId policyNftId,
|
244
|
+
ClaimId claimId,
|
245
|
+
bytes memory data
|
246
|
+
)
|
247
|
+
internal
|
248
|
+
{
|
249
|
+
_getProductStorage()._claimService.decline(
|
250
|
+
policyNftId,
|
251
|
+
claimId,
|
252
|
+
data);
|
253
|
+
}
|
254
|
+
|
255
|
+
function _closeClaim(
|
256
|
+
NftId policyNftId,
|
257
|
+
ClaimId claimId
|
258
|
+
)
|
259
|
+
internal
|
260
|
+
{
|
261
|
+
_getProductStorage()._claimService.close(
|
262
|
+
policyNftId,
|
263
|
+
claimId);
|
264
|
+
}
|
265
|
+
|
266
|
+
function _createPayout(
|
267
|
+
NftId policyNftId,
|
268
|
+
ClaimId claimId,
|
269
|
+
Amount amount,
|
270
|
+
bytes memory data
|
271
|
+
)
|
272
|
+
internal
|
273
|
+
returns (PayoutId)
|
274
|
+
{
|
275
|
+
return _getProductStorage()._claimService.createPayout(
|
276
|
+
policyNftId,
|
277
|
+
claimId,
|
278
|
+
amount,
|
279
|
+
data);
|
280
|
+
}
|
281
|
+
|
282
|
+
function _processPayout(
|
283
|
+
NftId policyNftId,
|
284
|
+
PayoutId payoutId
|
285
|
+
)
|
286
|
+
internal
|
287
|
+
{
|
288
|
+
_getProductStorage()._claimService.processPayout(
|
289
|
+
policyNftId,
|
290
|
+
payoutId);
|
291
|
+
}
|
292
|
+
|
293
|
+
function calculatePremium(
|
294
|
+
Amount sumInsuredAmount,
|
295
|
+
RiskId riskId,
|
296
|
+
Seconds lifetime,
|
297
|
+
bytes memory applicationData,
|
298
|
+
NftId bundleNftId,
|
299
|
+
ReferralId referralId
|
300
|
+
)
|
301
|
+
external
|
302
|
+
view
|
303
|
+
override
|
304
|
+
returns (Amount premiumAmount)
|
305
|
+
{
|
306
|
+
IPolicy.Premium memory premium = _getProductStorage()._pricingService.calculatePremium(
|
307
|
+
getNftId(),
|
308
|
+
riskId,
|
309
|
+
sumInsuredAmount,
|
310
|
+
lifetime,
|
311
|
+
applicationData,
|
312
|
+
bundleNftId,
|
313
|
+
referralId
|
314
|
+
);
|
315
|
+
|
316
|
+
return AmountLib.toAmount(premium.premiumAmount);
|
317
|
+
}
|
318
|
+
|
319
|
+
function calculateNetPremium(
|
320
|
+
Amount sumInsuredAmount,
|
321
|
+
RiskId riskId,
|
322
|
+
Seconds lifetime,
|
323
|
+
bytes memory applicationData
|
324
|
+
)
|
325
|
+
external
|
326
|
+
view
|
327
|
+
virtual override
|
328
|
+
returns (Amount netPremiumAmount)
|
329
|
+
{
|
330
|
+
// default 10% of sum insured
|
331
|
+
return AmountLib.toAmount(sumInsuredAmount.toInt() / 10);
|
332
|
+
}
|
333
|
+
|
334
|
+
|
335
|
+
function getInitialProductInfo()
|
336
|
+
public
|
337
|
+
virtual
|
338
|
+
view
|
339
|
+
returns (IComponents.ProductInfo memory poolInfo)
|
340
|
+
{
|
341
|
+
ProductStorage storage $ = _getProductStorage();
|
342
|
+
|
343
|
+
return IComponents.ProductInfo({
|
344
|
+
distributionNftId: $._distributionNftId,
|
345
|
+
poolNftId: $._poolNftId,
|
346
|
+
productFee: FeeLib.zero(),
|
347
|
+
processingFee: FeeLib.zero(),
|
348
|
+
distributionFee: FeeLib.zero(),
|
349
|
+
minDistributionOwnerFee: FeeLib.zero(),
|
350
|
+
poolFee: FeeLib.zero(),
|
351
|
+
stakingFee: FeeLib.zero(),
|
352
|
+
performanceFee: FeeLib.zero()
|
353
|
+
});
|
354
|
+
}
|
355
|
+
|
356
|
+
function getPoolNftId() external view override returns (NftId poolNftId) {
|
357
|
+
return getRegistry().getNftId(address(_getProductStorage()._pool));
|
358
|
+
}
|
359
|
+
|
360
|
+
function getDistributionNftId() external view override returns (NftId distributionNftId) {
|
361
|
+
return getRegistry().getNftId(address(_getProductStorage()._distribution));
|
362
|
+
}
|
363
|
+
|
364
|
+
function _toRiskId(string memory riskName) internal pure returns (RiskId riskId) {
|
365
|
+
return RiskIdLib.toRiskId(riskName);
|
366
|
+
}
|
367
|
+
|
368
|
+
function _getProductStorage() private pure returns (ProductStorage storage $) {
|
369
|
+
assembly {
|
370
|
+
$.slot := PRODUCT_STORAGE_LOCATION_V1
|
371
|
+
}
|
372
|
+
}
|
373
|
+
|
374
|
+
function _getProductService() internal view returns (IProductService) {
|
375
|
+
return _getProductStorage()._productService;
|
376
|
+
}
|
377
|
+
}
|
@@ -0,0 +1,124 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
5
|
+
import {IProductComponent} from "./IProductComponent.sol";
|
6
|
+
import {Product} from "./Product.sol";
|
7
|
+
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
8
|
+
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
9
|
+
import {IDistributionComponent} from "../distribution/IDistributionComponent.sol";
|
10
|
+
import {IInstance} from "../instance/IInstance.sol";
|
11
|
+
import {IPolicy} from "../instance/module/IPolicy.sol";
|
12
|
+
import {IRisk} from "../instance/module/IRisk.sol";
|
13
|
+
import {IBundle} from "../instance/module/IBundle.sol";
|
14
|
+
import {IProductService} from "./IProductService.sol";
|
15
|
+
import {IComponents} from "../instance/module/IComponents.sol";
|
16
|
+
|
17
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
18
|
+
|
19
|
+
import {IVersionable} from "../shared/IVersionable.sol";
|
20
|
+
import {Versionable} from "../shared/Versionable.sol";
|
21
|
+
|
22
|
+
import {Timestamp, zeroTimestamp} from "../type/Timestamp.sol";
|
23
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
24
|
+
import {Blocknumber, blockNumber} from "../type/Blocknumber.sol";
|
25
|
+
import {ObjectType, INSTANCE, PRODUCT, POOL, POLICY, REGISTRY} from "../type/ObjectType.sol";
|
26
|
+
import {APPLIED, ACTIVE, KEEP_STATE} from "../type/StateId.sol";
|
27
|
+
import {NftId, NftIdLib} from "../type/NftId.sol";
|
28
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
29
|
+
import {ReferralId} from "../type/Referral.sol";
|
30
|
+
import {RiskId} from "../type/RiskId.sol";
|
31
|
+
import {StateId} from "../type/StateId.sol";
|
32
|
+
import {Version, VersionLib} from "../type/Version.sol";
|
33
|
+
import {RoleId, PRODUCT_OWNER_ROLE} from "../type/RoleId.sol";
|
34
|
+
|
35
|
+
import {IService} from "../shared/IService.sol";
|
36
|
+
import {Service} from "../shared/Service.sol";
|
37
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
38
|
+
import {IInstanceService} from "../instance/IInstanceService.sol";
|
39
|
+
import {IProductService} from "./IProductService.sol";
|
40
|
+
import {IRegistryService} from "../registry/IRegistryService.sol";
|
41
|
+
import {InstanceReader} from "../instance/InstanceReader.sol";
|
42
|
+
import {IPoolService} from "../pool/PoolService.sol";
|
43
|
+
|
44
|
+
contract ProductService is
|
45
|
+
ComponentVerifyingService,
|
46
|
+
IProductService
|
47
|
+
{
|
48
|
+
IInstanceService private _instanceService;
|
49
|
+
IPoolService internal _poolService;
|
50
|
+
IRegistryService private _registryService;
|
51
|
+
|
52
|
+
event LogProductServiceSender(address sender);
|
53
|
+
|
54
|
+
function _initialize(
|
55
|
+
address owner,
|
56
|
+
bytes memory data
|
57
|
+
)
|
58
|
+
internal
|
59
|
+
initializer
|
60
|
+
virtual override
|
61
|
+
{
|
62
|
+
(
|
63
|
+
address registryAddress,,
|
64
|
+
//address managerAddress
|
65
|
+
address authority
|
66
|
+
) = abi.decode(data, (address, address, address));
|
67
|
+
|
68
|
+
initializeService(registryAddress, authority, owner);
|
69
|
+
|
70
|
+
_instanceService = IInstanceService(_getServiceAddress(INSTANCE()));
|
71
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getVersion().toMajorPart()));
|
72
|
+
_registryService = IRegistryService(_getServiceAddress(REGISTRY()));
|
73
|
+
|
74
|
+
registerInterface(type(IProductService).interfaceId);
|
75
|
+
}
|
76
|
+
|
77
|
+
|
78
|
+
function getDomain() public pure override returns(ObjectType) {
|
79
|
+
return PRODUCT();
|
80
|
+
}
|
81
|
+
|
82
|
+
|
83
|
+
function createRisk(
|
84
|
+
RiskId riskId,
|
85
|
+
bytes memory data
|
86
|
+
)
|
87
|
+
external
|
88
|
+
override
|
89
|
+
{
|
90
|
+
(NftId productNftId,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
91
|
+
IRisk.RiskInfo memory riskInfo = IRisk.RiskInfo(productNftId, data);
|
92
|
+
|
93
|
+
instance.getInstanceStore().createRisk(
|
94
|
+
riskId,
|
95
|
+
riskInfo
|
96
|
+
);
|
97
|
+
}
|
98
|
+
|
99
|
+
|
100
|
+
function updateRisk(
|
101
|
+
RiskId riskId,
|
102
|
+
bytes memory data
|
103
|
+
)
|
104
|
+
external
|
105
|
+
{
|
106
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
107
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
108
|
+
|
109
|
+
IRisk.RiskInfo memory riskInfo = instanceReader.getRiskInfo(riskId);
|
110
|
+
riskInfo.data = data;
|
111
|
+
instance.getInstanceStore().updateRisk(riskId, riskInfo, KEEP_STATE());
|
112
|
+
}
|
113
|
+
|
114
|
+
|
115
|
+
function updateRiskState(
|
116
|
+
RiskId riskId,
|
117
|
+
StateId state
|
118
|
+
)
|
119
|
+
external
|
120
|
+
{
|
121
|
+
(,, IInstance instance) = _getAndVerifyActiveComponent(PRODUCT());
|
122
|
+
instance.getInstanceStore().updateRiskState(riskId, state);
|
123
|
+
}
|
124
|
+
}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IVersionable} from "../shared/IVersionable.sol";
|
5
|
+
import {ProxyManager} from "../shared/ProxyManager.sol";
|
6
|
+
import {ProductService} from "./ProductService.sol";
|
7
|
+
import {Registry} from "../registry/Registry.sol";
|
8
|
+
import {RegistryService} from "../registry/RegistryService.sol";
|
9
|
+
import {VersionLib} from "../type/Version.sol";
|
10
|
+
|
11
|
+
contract ProductServiceManager is ProxyManager {
|
12
|
+
|
13
|
+
ProductService private _productService;
|
14
|
+
|
15
|
+
/// @dev initializes proxy manager with product service implementation
|
16
|
+
constructor(
|
17
|
+
address authority,
|
18
|
+
address registryAddress,
|
19
|
+
bytes32 salt
|
20
|
+
)
|
21
|
+
ProxyManager(registryAddress)
|
22
|
+
{
|
23
|
+
ProductService svc = new ProductService{salt: salt}();
|
24
|
+
bytes memory data = abi.encode(registryAddress, address(this), authority);
|
25
|
+
IVersionable versionable = deployDetermenistic(
|
26
|
+
address(svc),
|
27
|
+
data,
|
28
|
+
salt);
|
29
|
+
|
30
|
+
_productService = ProductService(address(versionable));
|
31
|
+
}
|
32
|
+
|
33
|
+
//--- view functions ----------------------------------------------------//
|
34
|
+
function getProductService()
|
35
|
+
external
|
36
|
+
view
|
37
|
+
returns (ProductService productService)
|
38
|
+
{
|
39
|
+
return _productService;
|
40
|
+
}
|
41
|
+
|
42
|
+
}
|
@@ -59,7 +59,13 @@ contract ChainNft is ERC721Enumerable {
|
|
59
59
|
}
|
60
60
|
|
61
61
|
_chainIdMultiplier = 10 ** _chainIdDigits;
|
62
|
-
|
62
|
+
|
63
|
+
// the first object registered through normal registration starts with id 4
|
64
|
+
// 1 -> protocol
|
65
|
+
// 2 -> registry
|
66
|
+
// 3 -> staking
|
67
|
+
// >= 4 -> all other objects
|
68
|
+
_idNext = 4;
|
63
69
|
}
|
64
70
|
|
65
71
|
/**
|
@@ -95,6 +101,10 @@ contract ChainNft is ERC721Enumerable {
|
|
95
101
|
|
96
102
|
_totalMinted++;
|
97
103
|
_safeMint(to, tokenId);
|
104
|
+
|
105
|
+
if(interceptor != address(0)) {
|
106
|
+
ITransferInterceptor(interceptor).nftMint(to, tokenId);
|
107
|
+
}
|
98
108
|
}
|
99
109
|
|
100
110
|
|
@@ -195,6 +205,10 @@ contract ChainNft is ERC721Enumerable {
|
|
195
205
|
_chainIdDigits;
|
196
206
|
}
|
197
207
|
|
208
|
+
function getNextTokenId() external view returns (uint256) {
|
209
|
+
return calculateTokenId(_idNext);
|
210
|
+
}
|
211
|
+
|
198
212
|
function _getNextTokenId() private returns (uint256 id) {
|
199
213
|
id = calculateTokenId(_idNext);
|
200
214
|
_idNext++;
|
@@ -3,11 +3,11 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
10
|
-
import {
|
6
|
+
import {NftId} from "../type/NftId.sol";
|
7
|
+
import {ObjectType} from "../type/ObjectType.sol";
|
8
|
+
import {VersionPart} from "../type/Version.sol";
|
9
|
+
import {Timestamp} from "../type/Timestamp.sol";
|
10
|
+
import {RoleId} from "../type/RoleId.sol";
|
11
11
|
|
12
12
|
interface IRegistry is IERC165 {
|
13
13
|
|
@@ -15,20 +15,27 @@ interface IRegistry is IERC165 {
|
|
15
15
|
event LogServiceRegistration(VersionPart majorVersion, ObjectType domain);
|
16
16
|
|
17
17
|
// registerService()
|
18
|
-
error
|
19
|
-
error
|
18
|
+
error ErrorRegistryCallerNotReleaseManager();
|
19
|
+
error ErrorRegistryDomainZero(address service);
|
20
|
+
error ErrorRegistryDomainAlreadyRegistered(address service, VersionPart version, ObjectType domain);
|
20
21
|
|
21
22
|
// register()
|
22
|
-
error
|
23
|
-
error ServiceRegistration();
|
23
|
+
error ErrorRegistryCallerNotRegistryService();
|
24
24
|
|
25
25
|
// registerWithCustomTypes()
|
26
|
-
error
|
26
|
+
error ErrorRegistryCoreTypeRegistration();
|
27
|
+
|
28
|
+
// setTokenRegistry()
|
29
|
+
error TokenRegistryZero();
|
30
|
+
error TokenRegistryAlreadySet(address tokenRegistry);
|
27
31
|
|
28
32
|
// _register()
|
29
|
-
error
|
30
|
-
error
|
31
|
-
error
|
33
|
+
error ErrorRegistryParentAddressZero();
|
34
|
+
error ErrorRegistryTypesCombinationInvalid(ObjectType objectType, ObjectType parentType);
|
35
|
+
error ErrorRegistryContractAlreadyRegistered(address objectAddress);
|
36
|
+
|
37
|
+
// _registerStaking()
|
38
|
+
error StakingAlreadyRegistered(address stakingAddress);
|
32
39
|
|
33
40
|
struct ObjectInfo {
|
34
41
|
NftId nftId;
|
@@ -38,13 +45,16 @@ interface IRegistry is IERC165 {
|
|
38
45
|
address objectAddress;
|
39
46
|
address initialOwner;
|
40
47
|
bytes data;
|
41
|
-
}
|
42
|
-
// TODO strong disagree, keep nftId there (lets keep get object info return object consistent)
|
48
|
+
}
|
43
49
|
|
44
50
|
struct ReleaseInfo {
|
51
|
+
VersionPart version;
|
52
|
+
address[] addresses;
|
53
|
+
RoleId[][] serviceRoles;
|
54
|
+
RoleId[][] functionRoles;
|
55
|
+
bytes4[][][] selectors;
|
45
56
|
ObjectType[] domains;
|
46
|
-
Timestamp
|
47
|
-
//Timestamp updatedAt;
|
57
|
+
Timestamp activatedAt;
|
48
58
|
}
|
49
59
|
|
50
60
|
function registerService(
|
@@ -85,6 +95,8 @@ interface IRegistry is IERC165 {
|
|
85
95
|
|
86
96
|
function isRegisteredService(address contractAddress) external view returns (bool);
|
87
97
|
|
98
|
+
function isRegisteredComponent(address object) external view returns (bool);
|
99
|
+
|
88
100
|
function isValidRelease(VersionPart version) external view returns (bool);
|
89
101
|
|
90
102
|
function getServiceAddress(
|
@@ -92,7 +104,15 @@ interface IRegistry is IERC165 {
|
|
92
104
|
VersionPart releaseVersion
|
93
105
|
) external view returns (address serviceAddress);
|
94
106
|
|
95
|
-
function
|
107
|
+
function getStakingAddress() external view returns (address staking);
|
108
|
+
|
109
|
+
function getTokenRegistryAddress() external view returns (address);
|
110
|
+
|
111
|
+
function getReleaseManagerAddress() external view returns (address);
|
112
|
+
|
113
|
+
function getReleaseAccessManagerAddress(VersionPart version) external view returns (address);
|
114
|
+
|
115
|
+
function getChainNftAddress() external view returns (address);
|
96
116
|
|
97
117
|
function getOwner() external view returns (address);
|
98
118
|
}
|