@etherisc/gif-next 0.0.2-e9a637d-547 → 0.0.2-eadf4ad-211
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 +6 -12
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/Distribution.sol/Distribution.json +61 -14
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1556 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +819 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → distribution}/IDistributionComponent.sol/IDistributionComponent.json +45 -14
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → distribution}/IDistributionService.sol/IDistributionService.json +24 -274
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +6 -6
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +93 -13
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +5 -43
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +109 -29
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +6 -6
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +124 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +349 -64
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +49 -278
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +83 -133
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +427 -257
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{Cloneable.sol → base/Cloneable.sol}/Cloneable.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +49 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +61 -12
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +8 -8
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol}/ObjectManager.json +3 -3
- 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/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1288 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +735 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IBundleService.sol/IBundleService.json +105 -29
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/IPoolComponent.sol/IPoolComponent.json +56 -25
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → pool}/IPoolService.sol/IPoolService.json +272 -39
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/{components → pool}/Pool.sol/Pool.json +56 -25
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1622 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +747 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +918 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +687 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1386 -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/IClaimService.sol/IClaimService.json → product/IApplicationService.sol/IApplicationService.json} +119 -101
- 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 +129 -84
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IApplicationService.sol/IApplicationService.json → product/IPricingService.sol/IPricingService.json} +63 -175
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/IProductComponent.sol/IProductComponent.json +53 -22
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service → product}/IProductService.sol/IProductService.json +6 -14
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1281 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +779 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +727 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/{components → product}/Product.sol/Product.json +53 -22
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +864 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +679 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +73 -13
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +154 -60
- 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 +97 -29
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +50 -97
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +174 -80
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +78 -47
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +369 -82
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +14 -27
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/{instance → shared}/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +3 -3
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/Component.sol/Component.json +38 -7
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ComponentService.sol/ComponentService.json +38 -14
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{components → shared}/IComponent.sol/IComponent.json +38 -7
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +0 -13
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +69 -9
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +0 -13
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +5 -13
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +8 -21
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +80 -26
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +49 -33
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +8 -21
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +5 -13
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +24 -6
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +523 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +767 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +667 -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 +3 -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/{types → type}/NftId.sol/NftIdLib.json +5 -5
- 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/{types → type}/Referral.sol/ReferralLib.json +5 -5
- 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/{types → type}/Seconds.sol/SecondsLib.json +3 -3
- 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 +20 -7
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/MathLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/UFixed.sol/UFixedLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionLib.json +3 -3
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/{types → type}/Version.sol/VersionPartLib.json +3 -3
- package/contracts/{components → distribution}/Distribution.sol +21 -16
- package/contracts/{instance/service → distribution}/DistributionService.sol +93 -179
- package/contracts/{instance/service → distribution}/DistributionServiceManager.sol +14 -11
- package/contracts/{components → distribution}/IDistributionComponent.sol +7 -7
- package/contracts/{instance/service → distribution}/IDistributionService.sol +18 -30
- package/contracts/instance/BundleManager.sol +8 -9
- package/contracts/instance/IInstance.sol +30 -13
- package/contracts/instance/IInstanceService.sol +6 -17
- package/contracts/instance/Instance.sol +76 -46
- package/contracts/instance/InstanceAccessManager.sol +8 -5
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +91 -16
- package/contracts/instance/InstanceService.sol +78 -307
- package/contracts/instance/InstanceServiceManager.sol +11 -21
- package/contracts/instance/InstanceStore.sol +57 -65
- package/contracts/instance/{Cloneable.sol → base/Cloneable.sol} +1 -1
- package/contracts/instance/base/IKeyValueStore.sol +14 -10
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +32 -43
- package/contracts/instance/base/Lifecycle.sol +17 -5
- package/contracts/instance/{ObjectManager.sol → base/ObjectManager.sol} +7 -7
- package/contracts/instance/module/IAccess.sol +2 -2
- package/contracts/instance/module/IBundle.sol +5 -5
- package/contracts/instance/module/IComponents.sol +8 -8
- package/contracts/instance/module/IDistribution.sol +7 -6
- package/contracts/instance/module/IPolicy.sol +22 -16
- package/contracts/instance/module/IRisk.sol +1 -1
- package/contracts/instance/module/ISetup.sol +4 -4
- package/contracts/instance/module/ITreasury.sol +2 -2
- package/contracts/{instance/service → pool}/BundleService.sol +108 -155
- package/contracts/pool/BundleServiceManager.sol +42 -0
- package/contracts/{instance/service → pool}/IBundleService.sol +43 -18
- package/contracts/{components → pool}/IPoolComponent.sol +14 -13
- package/contracts/{instance/service → pool}/IPoolService.sol +28 -13
- package/contracts/{components → pool}/Pool.sol +20 -21
- package/contracts/{instance/service → pool}/PoolService.sol +160 -59
- package/contracts/pool/PoolServiceManager.sol +42 -0
- package/contracts/product/ApplicationService.sol +187 -0
- package/contracts/{instance/service → product}/ApplicationServiceManager.sol +11 -8
- package/contracts/product/ClaimService.sol +443 -0
- package/contracts/{instance/service → product}/ClaimServiceManager.sol +11 -8
- package/contracts/{instance/service → product}/IApplicationService.sol +14 -34
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/{instance/service → product}/IPolicyService.sol +34 -26
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/{components → product}/IProductComponent.sol +11 -10
- package/contracts/{instance/service → product}/IProductService.sol +10 -10
- package/contracts/{instance/service → product}/PolicyService.sol +154 -138
- package/contracts/product/PolicyServiceManager.sol +42 -0
- package/contracts/product/PricingService.sol +276 -0
- package/contracts/product/PricingServiceManager.sol +42 -0
- package/contracts/{components → product}/Product.sol +160 -74
- package/contracts/{instance/service → product}/ProductService.sol +50 -47
- package/contracts/product/ProductServiceManager.sol +42 -0
- package/contracts/registry/IRegistry.sol +23 -16
- package/contracts/registry/IRegistryService.sol +26 -36
- package/contracts/registry/Registry.sol +43 -39
- package/contracts/registry/RegistryAccessManager.sol +39 -123
- package/contracts/registry/RegistryService.sol +32 -83
- package/contracts/registry/RegistryServiceManager.sol +21 -11
- package/contracts/registry/ReleaseManager.sol +247 -189
- package/contracts/registry/TokenRegistry.sol +2 -2
- package/contracts/{components → shared}/Component.sol +26 -8
- package/contracts/{instance/base → shared}/ComponentService.sol +60 -40
- package/contracts/{components → shared}/IComponent.sol +19 -5
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +24 -10
- package/contracts/shared/IRegistryLinked.sol +0 -1
- package/contracts/shared/IService.sol +3 -1
- package/contracts/shared/IVersionable.sol +1 -1
- package/contracts/shared/NftOwnable.sol +1 -3
- package/contracts/shared/PolicyHolder.sol +31 -18
- package/contracts/shared/ProxyManager.sol +29 -3
- package/contracts/shared/Registerable.sol +12 -11
- package/contracts/shared/RegistryLinked.sol +0 -5
- package/contracts/shared/Service.sol +3 -3
- package/contracts/shared/TokenHandler.sol +4 -2
- package/contracts/shared/Versionable.sol +1 -1
- package/contracts/staking/IStakingService.sol +102 -0
- package/contracts/staking/StakingService.sol +169 -0
- package/contracts/staking/StakingServiceManager.sol +40 -0
- package/contracts/{types → type}/Amount.sol +49 -0
- package/contracts/{types → type}/ClaimId.sol +25 -2
- package/contracts/{types → type}/Fee.sol +7 -6
- package/contracts/{types → type}/NftIdSet.sol +1 -1
- package/contracts/{types → type}/ObjectType.sol +10 -5
- package/contracts/{types → type}/PayoutId.sol +33 -5
- package/contracts/{types → type}/RoleId.sol +50 -8
- package/contracts/{types → type}/StateId.sol +6 -2
- package/contracts/{types → type}/Timestamp.sol +5 -0
- package/package.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +0 -4
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- 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/base/ComponentService.sol/ComponentService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +0 -1039
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +0 -673
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +0 -1231
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +0 -721
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +0 -817
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +0 -641
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +0 -1798
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +0 -805
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/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 -1092
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +0 -697
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +0 -1237
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +0 -661
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +0 -840
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +0 -653
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +0 -107
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +0 -4
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +0 -119
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +0 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +0 -383
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +0 -4
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +0 -116
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +0 -4
- package/artifacts/contracts/test/TestService.sol/TestService.json +0 -596
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +0 -4
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +0 -376
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +0 -218
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +0 -4
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +0 -104
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +0 -4
- package/artifacts/contracts/test/Usdc.sol/USDC.json +0 -376
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +0 -4
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +0 -4
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +0 -161
- 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/ClaimId.sol/ClaimIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +0 -100
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +0 -4
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +0 -288
- 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/NftIdSet.sol/LibNftIdSet.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +0 -100
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +0 -4
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +0 -100
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +0 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.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/instance/service/ApplicationService.sol +0 -351
- package/contracts/instance/service/BundleServiceManager.sol +0 -51
- package/contracts/instance/service/ClaimService.sol +0 -151
- package/contracts/instance/service/IClaimService.sol +0 -61
- package/contracts/instance/service/PolicyServiceManager.sol +0 -54
- package/contracts/instance/service/PoolServiceManager.sol +0 -51
- 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/TestToken.sol +0 -26
- 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/{instance → shared}/AccessManagerUpgradeableInitializeable.sol +0 -0
- /package/contracts/{types → type}/AddressSet.sol +0 -0
- /package/contracts/{types → type}/Blocknumber.sol +0 -0
- /package/contracts/{types → type}/DistributorType.sol +0 -0
- /package/contracts/{types → type}/Key32.sol +0 -0
- /package/contracts/{types → type}/NftId.sol +0 -0
- /package/contracts/{types → type}/Referral.sol +0 -0
- /package/contracts/{types → type}/RiskId.sol +0 -0
- /package/contracts/{types → type}/Seconds.sol +0 -0
- /package/contracts/{types → type}/UFixed.sol +0 -0
- /package/contracts/{types → type}/Version.sol +0 -0
@@ -3,18 +3,18 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
5
|
|
6
|
-
import {Key32, KeyId, Key32Lib} from "../
|
7
|
-
import {NftId} from "../
|
8
|
-
import {ClaimId} from "../
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
12
|
-
import {
|
13
|
-
import {
|
14
|
-
import {
|
15
|
-
import {
|
16
|
-
|
17
|
-
|
6
|
+
import {Key32, KeyId, Key32Lib} from "../type/Key32.sol";
|
7
|
+
import {NftId} from "../type/NftId.sol";
|
8
|
+
import {ClaimId} from "../type/ClaimId.sol";
|
9
|
+
import {ObjectType, BUNDLE, DISTRIBUTION, INSTANCE, POLICY, POOL, ROLE, PRODUCT, TARGET, COMPONENT, DISTRIBUTOR, DISTRIBUTOR_TYPE} from "../type/ObjectType.sol";
|
10
|
+
import {RiskId, RiskIdLib} from "../type/RiskId.sol";
|
11
|
+
import {RoleId, RoleIdLib, INSTANCE_ROLE, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
12
|
+
import {StateId, ACTIVE} from "../type/StateId.sol";
|
13
|
+
import {TimestampLib} from "../type/Timestamp.sol";
|
14
|
+
import {VersionPart, VersionPartLib} from "../type/Version.sol";
|
15
|
+
import {ReferralId} from "../type/Referral.sol";
|
16
|
+
import {DistributorType} from "../type/DistributorType.sol";
|
17
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
18
18
|
|
19
19
|
import {IInstance} from "./IInstance.sol";
|
20
20
|
import {KeyValueStore} from "./base/KeyValueStore.sol";
|
@@ -80,55 +80,55 @@ contract InstanceStore is AccessManagedUpgradeable, KeyValueStore
|
|
80
80
|
}
|
81
81
|
|
82
82
|
//--- DistributorType -------------------------------------------------------//
|
83
|
-
function createDistributorType(
|
84
|
-
create(
|
83
|
+
function createDistributorType(DistributorType distributorType, IDistribution.DistributorTypeInfo memory info) external restricted() {
|
84
|
+
create(distributorType.toKey32(), abi.encode(info));
|
85
85
|
}
|
86
86
|
|
87
|
-
function updateDistributorType(
|
88
|
-
update(
|
87
|
+
function updateDistributorType(DistributorType distributorType, IDistribution.DistributorTypeInfo memory info, StateId newState) external restricted() {
|
88
|
+
update(distributorType.toKey32(), abi.encode(info), newState);
|
89
89
|
}
|
90
90
|
|
91
|
-
function updateDistributorTypeState(
|
92
|
-
updateState(
|
91
|
+
function updateDistributorTypeState(DistributorType distributorType, StateId newState) external restricted() {
|
92
|
+
updateState(distributorType.toKey32(), newState);
|
93
93
|
}
|
94
94
|
|
95
95
|
//--- Distributor -------------------------------------------------------//
|
96
|
-
function createDistributor(NftId
|
97
|
-
create(
|
96
|
+
function createDistributor(NftId distributorNftId, IDistribution.DistributorInfo memory info) external restricted() {
|
97
|
+
create(_toNftKey32(distributorNftId, DISTRIBUTOR()), abi.encode(info));
|
98
98
|
}
|
99
99
|
|
100
|
-
function updateDistributor(NftId
|
101
|
-
update(
|
100
|
+
function updateDistributor(NftId distributorNftId, IDistribution.DistributorInfo memory info, StateId newState) external restricted() {
|
101
|
+
update(_toNftKey32(distributorNftId, DISTRIBUTOR()), abi.encode(info), newState);
|
102
102
|
}
|
103
103
|
|
104
|
-
function updateDistributorState(NftId
|
105
|
-
updateState(
|
104
|
+
function updateDistributorState(NftId distributorNftId, StateId newState) external restricted() {
|
105
|
+
updateState(_toNftKey32(distributorNftId, DISTRIBUTOR()), newState);
|
106
106
|
}
|
107
107
|
|
108
108
|
//--- Referral ----------------------------------------------------------//
|
109
|
-
function createReferral(
|
110
|
-
create(
|
109
|
+
function createReferral(ReferralId referralId, IDistribution.ReferralInfo memory referralInfo) external restricted() {
|
110
|
+
create(referralId.toKey32(), abi.encode(referralInfo));
|
111
111
|
}
|
112
112
|
|
113
|
-
function updateReferral(
|
114
|
-
update(
|
113
|
+
function updateReferral(ReferralId referralId, IDistribution.ReferralInfo memory referralInfo, StateId newState) external restricted() {
|
114
|
+
update(referralId.toKey32(), abi.encode(referralInfo), newState);
|
115
115
|
}
|
116
116
|
|
117
|
-
function updateReferralState(
|
118
|
-
updateState(
|
117
|
+
function updateReferralState(ReferralId referralId, StateId newState) external restricted() {
|
118
|
+
updateState(referralId.toKey32(), newState);
|
119
119
|
}
|
120
120
|
|
121
121
|
//--- Bundle ------------------------------------------------------------//
|
122
122
|
function createBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle) external restricted() {
|
123
|
-
create(
|
123
|
+
create(_toNftKey32(bundleNftId, BUNDLE()), abi.encode(bundle));
|
124
124
|
}
|
125
125
|
|
126
126
|
function updateBundle(NftId bundleNftId, IBundle.BundleInfo memory bundle, StateId newState) external restricted() {
|
127
|
-
update(
|
127
|
+
update(_toNftKey32(bundleNftId, BUNDLE()), abi.encode(bundle), newState);
|
128
128
|
}
|
129
129
|
|
130
130
|
function updateBundleState(NftId bundleNftId, StateId newState) external restricted() {
|
131
|
-
updateState(
|
131
|
+
updateState(_toNftKey32(bundleNftId, BUNDLE()), newState);
|
132
132
|
}
|
133
133
|
|
134
134
|
//--- Risk --------------------------------------------------------------//
|
@@ -146,74 +146,66 @@ contract InstanceStore is AccessManagedUpgradeable, KeyValueStore
|
|
146
146
|
|
147
147
|
//--- Application (Policy) ----------------------------------------------//
|
148
148
|
function createApplication(NftId applicationNftId, IPolicy.PolicyInfo memory policy) external restricted() {
|
149
|
-
create(
|
149
|
+
create(_toNftKey32(applicationNftId, POLICY()), abi.encode(policy));
|
150
150
|
}
|
151
151
|
|
152
152
|
function updateApplication(NftId applicationNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
153
|
-
update(
|
153
|
+
update(_toNftKey32(applicationNftId, POLICY()), abi.encode(policy), newState);
|
154
154
|
}
|
155
155
|
|
156
156
|
function updateApplicationState(NftId applicationNftId, StateId newState) external restricted() {
|
157
|
-
updateState(
|
157
|
+
updateState(_toNftKey32(applicationNftId, POLICY()), newState);
|
158
158
|
}
|
159
159
|
|
160
160
|
//--- Policy ------------------------------------------------------------//
|
161
161
|
function updatePolicy(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
162
|
-
update(
|
162
|
+
update(_toNftKey32(policyNftId, POLICY()), abi.encode(policy), newState);
|
163
|
+
}
|
164
|
+
|
165
|
+
function updatePolicyClaims(NftId policyNftId, IPolicy.PolicyInfo memory policy, StateId newState) external restricted() {
|
166
|
+
update(_toNftKey32(policyNftId, POLICY()), abi.encode(policy), newState);
|
163
167
|
}
|
164
168
|
|
165
169
|
function updatePolicyState(NftId policyNftId, StateId newState) external restricted() {
|
166
|
-
updateState(
|
170
|
+
updateState(_toNftKey32(policyNftId, POLICY()), newState);
|
167
171
|
}
|
168
172
|
|
169
173
|
//--- Claim -------------------------------------------------------------//
|
170
174
|
function createClaim(NftId policyNftId, ClaimId claimId, IPolicy.ClaimInfo memory claim) external restricted() {
|
171
|
-
create(
|
175
|
+
create(_toClaimKey32(policyNftId, claimId), abi.encode(claim));
|
172
176
|
}
|
173
177
|
|
174
178
|
function updateClaim(NftId policyNftId, ClaimId claimId, IPolicy.ClaimInfo memory claim, StateId newState) external restricted() {
|
175
|
-
update(
|
179
|
+
update(_toClaimKey32(policyNftId, claimId), abi.encode(claim), newState);
|
176
180
|
}
|
177
181
|
|
178
182
|
function updateClaimState(NftId policyNftId, ClaimId claimId, StateId newState) external restricted() {
|
179
|
-
updateState(
|
183
|
+
updateState(_toClaimKey32(policyNftId, claimId), newState);
|
180
184
|
}
|
181
185
|
|
182
186
|
//--- Payout ------------------------------------------------------------//
|
183
|
-
function createPayout(NftId policyNftId,
|
184
|
-
create(
|
187
|
+
function createPayout(NftId policyNftId, PayoutId payoutId, IPolicy.PayoutInfo memory payout) external restricted() {
|
188
|
+
create(_toPayoutKey32(policyNftId, payoutId), abi.encode(payout));
|
185
189
|
}
|
186
190
|
|
187
|
-
function updatePayout(NftId policyNftId,
|
188
|
-
update(
|
191
|
+
function updatePayout(NftId policyNftId, PayoutId payoutId, IPolicy.PayoutInfo memory payout, StateId newState) external restricted() {
|
192
|
+
update(_toPayoutKey32(policyNftId, payoutId), abi.encode(payout), newState);
|
189
193
|
}
|
190
194
|
|
191
|
-
function updatePayoutState(NftId policyNftId, StateId newState) external restricted() {
|
192
|
-
updateState(
|
195
|
+
function updatePayoutState(NftId policyNftId, PayoutId payoutId, StateId newState) external restricted() {
|
196
|
+
updateState(_toPayoutKey32(policyNftId, payoutId), newState);
|
193
197
|
}
|
194
198
|
|
195
199
|
//--- internal view/pure functions --------------------------------------//
|
196
|
-
function _toNftKey32(NftId nftId, ObjectType objectType)
|
200
|
+
function _toNftKey32(NftId nftId, ObjectType objectType) private pure returns (Key32) {
|
197
201
|
return nftId.toKey32(objectType);
|
198
202
|
}
|
199
203
|
|
200
|
-
function
|
201
|
-
return
|
202
|
-
}
|
203
|
-
|
204
|
-
function toPolicyKey32(NftId policyNftId) public pure returns (Key32) {
|
205
|
-
return policyNftId.toKey32(POLICY());
|
206
|
-
}
|
207
|
-
|
208
|
-
function toDistributionKey32(NftId distNftId) public pure returns (Key32) {
|
209
|
-
return distNftId.toKey32(DISTRIBUTION());
|
210
|
-
}
|
211
|
-
|
212
|
-
function toDistributorTypeKey32(NftId distNftId) public pure returns (Key32) {
|
213
|
-
return distNftId.toKey32(DISTRIBUTOR_TYPE());
|
204
|
+
function _toClaimKey32(NftId policyNftId, ClaimId claimId) private pure returns (Key32) {
|
205
|
+
return claimId.toKey32(policyNftId);
|
214
206
|
}
|
215
207
|
|
216
|
-
function
|
217
|
-
return
|
208
|
+
function _toPayoutKey32(NftId policyNftId, PayoutId payoutId) private pure returns (Key32) {
|
209
|
+
return payoutId.toKey32(policyNftId);
|
218
210
|
}
|
219
|
-
}
|
211
|
+
}
|
@@ -4,7 +4,7 @@ pragma solidity ^0.8.20;
|
|
4
4
|
import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
|
5
5
|
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
6
6
|
|
7
|
-
import {IRegistry} from "
|
7
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
8
8
|
|
9
9
|
abstract contract Cloneable is
|
10
10
|
AccessManagedUpgradeable
|
@@ -1,17 +1,25 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {Blocknumber, blockBlocknumber, zeroBlocknumber} from "../../
|
5
|
-
import {Key32, KeyId} from "../../
|
6
|
-
import {NftId} from "../../
|
7
|
-
import {ObjectType} from "../../
|
8
|
-
import {StateId} from "../../
|
4
|
+
import {Blocknumber, blockBlocknumber, zeroBlocknumber} from "../../type/Blocknumber.sol";
|
5
|
+
import {Key32, KeyId} from "../../type/Key32.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {ObjectType} from "../../type/ObjectType.sol";
|
8
|
+
import {StateId} from "../../type/StateId.sol";
|
9
9
|
|
10
10
|
import {ILifecycle} from "./ILifecycle.sol";
|
11
11
|
|
12
|
-
// TODO remove - internal only?
|
13
12
|
interface IKeyValueStore is ILifecycle {
|
14
13
|
|
14
|
+
error ErrorKeyValueStoreTypeUndefined(ObjectType objectType);
|
15
|
+
error ErrorKeyValueStoreAlreadyCreated(Key32 key, ObjectType objectType);
|
16
|
+
error ErrorKeyValueStoreStateZero(Key32 key);
|
17
|
+
error ErrorKeyValueStoreNotExisting(Key32 key);
|
18
|
+
|
19
|
+
event LogInfoCreated(ObjectType objectType, KeyId keyId, StateId state, address createdBy, address txOrigin);
|
20
|
+
event LogInfoUpdated(ObjectType objectType, KeyId keyId, StateId state, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
21
|
+
event LogStateUpdated(ObjectType objectType, KeyId keyId, StateId stateOld, StateId stateNew, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
22
|
+
|
15
23
|
struct Value {
|
16
24
|
Metadata metadata;
|
17
25
|
bytes data;
|
@@ -29,10 +37,6 @@ interface IKeyValueStore is ILifecycle {
|
|
29
37
|
Blocknumber createdIn;
|
30
38
|
}
|
31
39
|
|
32
|
-
event LogInfoCreated(ObjectType objectType, KeyId keyId, StateId state, address createdBy, address txOrigin);
|
33
|
-
event LogInfoUpdated(ObjectType objectType, KeyId keyId, StateId state, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
34
|
-
event LogStateUpdated(ObjectType objectType, KeyId keyId, StateId stateOld, StateId stateNew, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
|
35
|
-
|
36
40
|
// generic state changing functions
|
37
41
|
// function create(Key32 key, bytes memory data) external;
|
38
42
|
// function update(Key32 key, bytes memory data, StateId state) external;
|
@@ -1,9 +1,9 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {NftId} from "../../
|
5
|
-
import {ObjectType} from "../../
|
6
|
-
import {StateId} from "../../
|
4
|
+
import {NftId} from "../../type/NftId.sol";
|
5
|
+
import {ObjectType} from "../../type/ObjectType.sol";
|
6
|
+
import {StateId} from "../../type/StateId.sol";
|
7
7
|
|
8
8
|
interface ILifecycle {
|
9
9
|
|
@@ -1,17 +1,20 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {Blocknumber, blockBlocknumber, zeroBlocknumber} from "../../
|
5
|
-
import {Key32, KeyId, Key32Lib} from "../../
|
6
|
-
import {NftId} from "../../
|
7
|
-
import {ObjectType} from "../../
|
8
|
-
import {StateId, ACTIVE, KEEP_STATE} from "../../
|
9
|
-
import {Timestamp, TimestampLib} from "../../
|
4
|
+
import {Blocknumber, blockBlocknumber, zeroBlocknumber} from "../../type/Blocknumber.sol";
|
5
|
+
import {Key32, KeyId, Key32Lib} from "../../type/Key32.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {ObjectType} from "../../type/ObjectType.sol";
|
8
|
+
import {StateId, ACTIVE, KEEP_STATE} from "../../type/StateId.sol";
|
9
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
10
10
|
|
11
11
|
import {Lifecycle} from "./Lifecycle.sol";
|
12
12
|
import {IKeyValueStore} from "./IKeyValueStore.sol";
|
13
13
|
|
14
|
-
contract KeyValueStore is
|
14
|
+
contract KeyValueStore is
|
15
|
+
Lifecycle,
|
16
|
+
IKeyValueStore
|
17
|
+
{
|
15
18
|
|
16
19
|
mapping(Key32 key32 => Value value) private _value;
|
17
20
|
|
@@ -20,21 +23,16 @@ contract KeyValueStore is Lifecycle, IKeyValueStore {
|
|
20
23
|
bytes memory data
|
21
24
|
)
|
22
25
|
internal
|
23
|
-
{
|
24
|
-
_create(key32, data);
|
25
|
-
}
|
26
|
-
|
27
|
-
function _create(
|
28
|
-
Key32 key32,
|
29
|
-
bytes memory data
|
30
|
-
)
|
31
|
-
internal
|
32
26
|
{
|
33
27
|
ObjectType objectType = key32.toObjectType();
|
34
|
-
|
28
|
+
if (objectType.eqz()) {
|
29
|
+
revert ErrorKeyValueStoreTypeUndefined(objectType);
|
30
|
+
}
|
35
31
|
|
36
32
|
Metadata storage metadata = _value[key32].metadata;
|
37
|
-
|
33
|
+
if (metadata.state.gtz()) {
|
34
|
+
revert ErrorKeyValueStoreAlreadyCreated(key32, objectType);
|
35
|
+
}
|
38
36
|
|
39
37
|
address createdBy = msg.sender;
|
40
38
|
Blocknumber blocknumber = blockBlocknumber();
|
@@ -61,26 +59,22 @@ contract KeyValueStore is Lifecycle, IKeyValueStore {
|
|
61
59
|
)
|
62
60
|
internal
|
63
61
|
{
|
64
|
-
|
65
|
-
|
62
|
+
if (state.eqz()) {
|
63
|
+
revert ErrorKeyValueStoreStateZero(key32);
|
64
|
+
}
|
66
65
|
|
67
|
-
function _update(
|
68
|
-
Key32 key32,
|
69
|
-
bytes memory data,
|
70
|
-
StateId state
|
71
|
-
)
|
72
|
-
internal
|
73
|
-
{
|
74
|
-
require(state.gtz(), "ERROR:KVS-020:STATE_UNDEFINED");
|
75
66
|
Metadata storage metadata = _value[key32].metadata;
|
76
67
|
StateId stateOld = metadata.state;
|
77
|
-
|
68
|
+
if (stateOld.eqz()) {
|
69
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
70
|
+
}
|
78
71
|
|
79
72
|
// update data
|
80
73
|
_value[key32].data = data;
|
81
74
|
|
82
75
|
// update state
|
83
76
|
if(state != KEEP_STATE()) {
|
77
|
+
checkTransition(metadata.objectType, stateOld, state);
|
84
78
|
metadata.state = state;
|
85
79
|
}
|
86
80
|
|
@@ -100,16 +94,12 @@ contract KeyValueStore is Lifecycle, IKeyValueStore {
|
|
100
94
|
|
101
95
|
function updateData(Key32 key32, bytes memory data)
|
102
96
|
internal
|
103
|
-
{
|
104
|
-
_updateData(key32, data);
|
105
|
-
}
|
106
|
-
|
107
|
-
function _updateData(Key32 key32, bytes memory data)
|
108
|
-
internal
|
109
97
|
{
|
110
98
|
Metadata storage metadata = _value[key32].metadata;
|
111
99
|
StateId state = metadata.state;
|
112
|
-
|
100
|
+
if (state.eqz()) {
|
101
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
102
|
+
}
|
113
103
|
|
114
104
|
// update data
|
115
105
|
_value[key32].data = data;
|
@@ -128,16 +118,15 @@ contract KeyValueStore is Lifecycle, IKeyValueStore {
|
|
128
118
|
function updateState(Key32 key32, StateId state)
|
129
119
|
internal
|
130
120
|
{
|
131
|
-
|
132
|
-
|
121
|
+
if (state.eqz()) {
|
122
|
+
revert ErrorKeyValueStoreStateZero(key32);
|
123
|
+
}
|
133
124
|
|
134
|
-
function _updateState(Key32 key32, StateId state)
|
135
|
-
internal
|
136
|
-
{
|
137
|
-
require(state.gtz(), "ERROR:KVS-040:STATE_UNDEFINED");
|
138
125
|
Metadata storage metadata = _value[key32].metadata;
|
139
126
|
StateId stateOld = metadata.state;
|
140
|
-
|
127
|
+
if (stateOld.eqz()) {
|
128
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
129
|
+
}
|
141
130
|
|
142
131
|
// ensure state transistion is valid
|
143
132
|
checkTransition(metadata.objectType, stateOld, state);
|
@@ -3,9 +3,9 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {Initializable} from "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol";
|
5
5
|
|
6
|
-
import {NftId} from "../../
|
7
|
-
import {ObjectType, COMPONENT, BUNDLE, POLICY, RISK} from "../../
|
8
|
-
import {StateId, ACTIVE, PAUSED, ARCHIVED, CLOSED, APPLIED,
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {ObjectType, COMPONENT, BUNDLE, POLICY, RISK, CLAIM, PAYOUT} from "../../type/ObjectType.sol";
|
8
|
+
import {StateId, ACTIVE, PAUSED, ARCHIVED, CLOSED, APPLIED, COLLATERALIZED, REVOKED, SUBMITTED, CONFIRMED, DECLINED, EXPECTED, PAID} from "../../type/StateId.sol";
|
9
9
|
import {ILifecycle} from "./ILifecycle.sol";
|
10
10
|
|
11
11
|
contract Lifecycle is
|
@@ -25,6 +25,7 @@ contract Lifecycle is
|
|
25
25
|
_setupBundleLifecycle();
|
26
26
|
_setupComponentLifecycle();
|
27
27
|
_setupPolicyLifecycle();
|
28
|
+
_setupClaimAndPayoutLifecycle();
|
28
29
|
_setupRiskLifecycle();
|
29
30
|
}
|
30
31
|
|
@@ -95,11 +96,22 @@ contract Lifecycle is
|
|
95
96
|
_initialState[POLICY()] = APPLIED();
|
96
97
|
_isValidTransition[POLICY()][APPLIED()][REVOKED()] = true;
|
97
98
|
_isValidTransition[POLICY()][APPLIED()][DECLINED()] = true;
|
98
|
-
_isValidTransition[POLICY()][APPLIED()][
|
99
|
-
_isValidTransition[POLICY()][
|
99
|
+
_isValidTransition[POLICY()][APPLIED()][COLLATERALIZED()] = true;
|
100
|
+
_isValidTransition[POLICY()][APPLIED()][ACTIVE()] = true;
|
101
|
+
_isValidTransition[POLICY()][COLLATERALIZED()][ACTIVE()] = true;
|
100
102
|
_isValidTransition[POLICY()][ACTIVE()][CLOSED()] = true;
|
101
103
|
}
|
102
104
|
|
105
|
+
function _setupClaimAndPayoutLifecycle() internal {
|
106
|
+
_initialState[CLAIM()] = SUBMITTED();
|
107
|
+
_isValidTransition[CLAIM()][SUBMITTED()][CONFIRMED()] = true;
|
108
|
+
_isValidTransition[CLAIM()][SUBMITTED()][DECLINED()] = true;
|
109
|
+
_isValidTransition[CLAIM()][CONFIRMED()][CLOSED()] = true;
|
110
|
+
|
111
|
+
_initialState[PAYOUT()] = EXPECTED();
|
112
|
+
_isValidTransition[PAYOUT()][EXPECTED()][PAID()] = true;
|
113
|
+
}
|
114
|
+
|
103
115
|
function _setupRiskLifecycle() internal {
|
104
116
|
_initialState[RISK()] = ACTIVE();
|
105
117
|
_isValidTransition[RISK()][ACTIVE()][PAUSED()] = true;
|
@@ -3,12 +3,12 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {Cloneable} from "./Cloneable.sol";
|
5
5
|
|
6
|
-
import {IInstance} from "
|
7
|
-
import {INSTANCE} from "
|
8
|
-
import {InstanceReader} from "
|
9
|
-
import {IRegistry} from "
|
10
|
-
import {LibNftIdSet} from "
|
11
|
-
import {NftId} from "
|
6
|
+
import {IInstance} from "../IInstance.sol";
|
7
|
+
import {INSTANCE} from "../../type/ObjectType.sol";
|
8
|
+
import {InstanceReader} from "../InstanceReader.sol";
|
9
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
10
|
+
import {LibNftIdSet} from "../../type/NftIdSet.sol";
|
11
|
+
import {NftId} from "../../type/NftId.sol";
|
12
12
|
|
13
13
|
contract ObjectManager is
|
14
14
|
Cloneable
|
@@ -29,7 +29,7 @@ contract ObjectManager is
|
|
29
29
|
external
|
30
30
|
{
|
31
31
|
IInstance instance = IInstance(instanceAddress);
|
32
|
-
initialize(instance.authority(), instance.
|
32
|
+
initialize(instance.authority(), address(instance.getRegistry()));
|
33
33
|
|
34
34
|
_instance = instance;
|
35
35
|
|
@@ -3,8 +3,8 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
5
5
|
|
6
|
-
import {RoleId} from "../../
|
7
|
-
import {Timestamp} from "../../
|
6
|
+
import {RoleId} from "../../type/RoleId.sol";
|
7
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
8
8
|
|
9
9
|
interface IAccess {
|
10
10
|
|
@@ -1,11 +1,11 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {Amount} from "../../
|
5
|
-
import {NftId} from "../../
|
6
|
-
import {Fee} from "../../
|
7
|
-
import {Seconds} from "../../
|
8
|
-
import {Timestamp} from "../../
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {NftId} from "../../type/NftId.sol";
|
6
|
+
import {Fee} from "../../type/Fee.sol";
|
7
|
+
import {Seconds} from "../../type/Seconds.sol";
|
8
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
9
9
|
|
10
10
|
interface IBundle {
|
11
11
|
|
@@ -3,12 +3,12 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {Amount} from "../../
|
7
|
-
import {Fee} from "../../
|
8
|
-
import {NftId} from "../../
|
9
|
-
import {RoleId} from "../../
|
6
|
+
import {Amount} from "../../type/Amount.sol";
|
7
|
+
import {Fee} from "../../type/Fee.sol";
|
8
|
+
import {NftId} from "../../type/NftId.sol";
|
9
|
+
import {RoleId} from "../../type/RoleId.sol";
|
10
10
|
import {TokenHandler} from "../../shared/TokenHandler.sol";
|
11
|
-
import {UFixed} from "../../
|
11
|
+
import {UFixed} from "../../type/UFixed.sol";
|
12
12
|
|
13
13
|
interface IComponents {
|
14
14
|
|
@@ -26,9 +26,9 @@ interface IComponents {
|
|
26
26
|
NftId productNftId; // the nft of the product this pool is linked to
|
27
27
|
RoleId bundleOwnerRole; // the required role for bundle owners
|
28
28
|
// TODO maxCapitalAmount -> maxBalanceAmount
|
29
|
-
|
30
|
-
|
31
|
-
|
29
|
+
Amount maxCapitalAmount; // max capital amount allowed for pool
|
30
|
+
Amount balanceAmount; // current pool balance (accounting view)
|
31
|
+
Amount feeAmount; // accumulated fee amount
|
32
32
|
bool isInterceptingBundleTransfers; // intercepts nft transfers for bundles
|
33
33
|
bool isExternallyManaged; // funding bundles is restricted to book keeping, actual funds may be provided as needed to support payouts
|
34
34
|
bool isVerifyingApplications; // underwriting requires the pool component checks/confirms the applications
|
@@ -1,10 +1,11 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
5
|
-
import {
|
6
|
-
import {
|
7
|
-
import {
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {DistributorType} from "../../type/DistributorType.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
8
|
+
import {UFixed} from "../../type/UFixed.sol";
|
8
9
|
|
9
10
|
interface IDistribution {
|
10
11
|
|
@@ -24,8 +25,8 @@ interface IDistribution {
|
|
24
25
|
DistributorType distributorType;
|
25
26
|
bool active;
|
26
27
|
bytes data;
|
27
|
-
|
28
|
-
|
28
|
+
Amount commissionAmount;
|
29
|
+
uint32 numPoliciesSold;
|
29
30
|
}
|
30
31
|
|
31
32
|
struct ReferralInfo {
|
@@ -1,12 +1,13 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
5
|
-
import {
|
6
|
-
import {
|
7
|
-
import {
|
8
|
-
import {
|
9
|
-
import {
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {NftId} from "../../type/NftId.sol";
|
6
|
+
import {ClaimId} from "../../type/ClaimId.sol";
|
7
|
+
import {ReferralId} from "../../type/Referral.sol";
|
8
|
+
import {RiskId} from "../../type/RiskId.sol";
|
9
|
+
import {Seconds} from "../../type/Seconds.sol";
|
10
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
10
11
|
|
11
12
|
interface IPolicy {
|
12
13
|
|
@@ -40,15 +41,17 @@ interface IPolicy {
|
|
40
41
|
NftId bundleNftId;
|
41
42
|
ReferralId referralId;
|
42
43
|
RiskId riskId;
|
43
|
-
|
44
|
-
|
45
|
-
|
44
|
+
Amount sumInsuredAmount;
|
45
|
+
Amount premiumAmount;
|
46
|
+
Amount premiumPaidAmount; // when lower than premium amount: max payout decreased accordingly
|
46
47
|
Seconds lifetime;
|
48
|
+
// policy application data, no changes after applying for a policy
|
47
49
|
bytes applicationData;
|
48
|
-
bytes
|
50
|
+
bytes processData;
|
49
51
|
uint16 claimsCount;
|
50
52
|
uint16 openClaimsCount;
|
51
|
-
|
53
|
+
Amount claimAmount; // sum of confirmed claim amounts (max = sum insured amount)
|
54
|
+
Amount payoutAmount; // sum of payouts (max = sum confirmed claim amountst)
|
52
55
|
Timestamp activatedAt; // time of underwriting
|
53
56
|
Timestamp expiredAt; // no new claims (activatedAt + lifetime)
|
54
57
|
Timestamp closedAt; // no locked capital (or declinedAt)
|
@@ -56,16 +59,19 @@ interface IPolicy {
|
|
56
59
|
|
57
60
|
// claimId neeeds to be encoded policyNftId:claimId combination
|
58
61
|
struct ClaimInfo {
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
62
|
+
Amount claimAmount;
|
63
|
+
Amount paidAmount;
|
64
|
+
uint8 payoutsCount;
|
65
|
+
uint8 openPayoutsCount;
|
66
|
+
bytes submissionData; // claim submission data, no changes after submitting the claim
|
67
|
+
bytes processData; // data that may include information supporting confirm or decline
|
68
|
+
Timestamp closedAt; // payment of confirmed claim amount (or declinedAt)
|
63
69
|
}
|
64
70
|
|
65
71
|
// claimId neeeds to be encoded policyNftId:claimId combination
|
66
72
|
struct PayoutInfo {
|
67
73
|
ClaimId claimId;
|
68
|
-
|
74
|
+
Amount amount;
|
69
75
|
bytes data;
|
70
76
|
Timestamp paidAt; // payoment of confirmed claim amount (or declinedAt)
|
71
77
|
}
|