@etherisc/gif-next 0.0.2-fe88ad7-208 → 0.0.2-ff8087d-237
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/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +873 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +903 -202
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{BaseComponent.sol/BaseComponent.json → IComponent.sol/IComponent.json} +237 -83
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +879 -31
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +879 -59
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +720 -16
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +760 -195
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +564 -141
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +1 -1
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +15 -15
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +69 -79
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +5 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1474 -483
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +248 -218
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +1152 -794
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +462 -179
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +414 -267
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +482 -346
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +355 -91
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +11 -40
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/{ComponentServiceBase.sol/ComponentServiceBase.json → ComponentService.sol/ComponentService.json} +263 -164
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- 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 +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- 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/IComponents.sol/IComponents.json +10 -0
- 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/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +1124 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +688 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +641 -303
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +343 -79
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +1384 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +752 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1434 -280
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +469 -73
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IApplicationService.sol/IApplicationService.json} +342 -189
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +310 -249
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +743 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +757 -144
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +262 -275
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +703 -125
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +71 -165
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +632 -344
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +367 -91
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +1119 -224
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +361 -73
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +297 -210
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +298 -78
- 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 +117 -5
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +99 -217
- 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 +131 -27
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +18 -18
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +205 -250
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +287 -81
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +81 -68
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +138 -50
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- 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/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 +189 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +8 -34
- 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 -165
- 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/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +107 -27
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +302 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +283 -63
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +116 -51
- 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 +173 -153
- 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/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +116 -51
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +191 -203
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +74 -19
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +38 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/Component.sol +272 -0
- package/contracts/components/Distribution.sol +204 -82
- package/contracts/components/IComponent.sol +90 -0
- package/contracts/components/IDistributionComponent.sol +44 -17
- package/contracts/components/IPoolComponent.sol +90 -42
- package/contracts/components/IProductComponent.sol +15 -9
- package/contracts/components/Pool.sol +217 -186
- package/contracts/components/Product.sol +246 -166
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +2 -12
- package/contracts/instance/BundleManager.sol +17 -20
- package/contracts/instance/Cloneable.sol +7 -2
- package/contracts/instance/IInstance.sol +67 -25
- package/contracts/instance/IInstanceService.sol +34 -11
- package/contracts/instance/Instance.sol +158 -116
- package/contracts/instance/InstanceAccessManager.sol +389 -165
- package/contracts/instance/InstanceReader.sol +87 -36
- package/contracts/instance/InstanceService.sol +295 -161
- package/contracts/instance/InstanceServiceManager.sol +1 -1
- package/contracts/instance/ObjectManager.sol +10 -29
- package/contracts/instance/base/ComponentService.sol +130 -0
- package/contracts/instance/base/KeyValueStore.sol +13 -36
- package/contracts/instance/base/Lifecycle.sol +26 -6
- package/contracts/instance/module/IAccess.sol +22 -16
- package/contracts/instance/module/IBundle.sol +8 -5
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +3 -0
- package/contracts/instance/module/IPolicy.sol +43 -11
- package/contracts/instance/module/ISetup.sol +7 -20
- package/contracts/instance/service/ApplicationService.sol +356 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +244 -119
- package/contracts/instance/service/BundleServiceManager.sol +1 -1
- package/contracts/instance/service/ClaimService.sol +443 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +360 -41
- package/contracts/instance/service/DistributionServiceManager.sol +1 -1
- package/contracts/instance/service/IApplicationService.sol +79 -0
- package/contracts/instance/service/IBundleService.sol +93 -20
- package/contracts/instance/service/IClaimService.sol +90 -0
- package/contracts/instance/service/IDistributionService.sol +89 -0
- package/contracts/instance/service/IPolicyService.sol +44 -51
- package/contracts/instance/service/IPoolService.sol +97 -3
- package/contracts/instance/service/PolicyService.sol +233 -364
- package/contracts/instance/service/PolicyServiceManager.sol +2 -2
- package/contracts/instance/service/PoolService.sol +319 -40
- package/contracts/instance/service/PoolServiceManager.sol +1 -1
- package/contracts/instance/service/ProductService.sol +90 -50
- package/contracts/instance/service/ProductServiceManager.sol +2 -2
- package/contracts/registry/ChainNft.sol +8 -0
- package/contracts/registry/IRegistry.sol +18 -8
- package/contracts/registry/IRegistryService.sol +21 -13
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +142 -71
- package/contracts/registry/RegistryAccessManager.sol +31 -25
- package/contracts/registry/RegistryService.sol +93 -134
- package/contracts/registry/RegistryServiceManager.sol +13 -13
- package/contracts/registry/ReleaseManager.sol +103 -127
- package/contracts/registry/TokenRegistry.sol +19 -13
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/INftOwnable.sol +11 -10
- package/contracts/shared/IPolicyHolder.sol +40 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/IVersionable.sol +4 -47
- package/contracts/shared/NftOwnable.sol +64 -80
- package/contracts/shared/PolicyHolder.sol +94 -0
- package/contracts/shared/ProxyManager.sol +100 -25
- package/contracts/shared/Registerable.sol +24 -39
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +36 -22
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/test/TestRegisterable.sol +1 -1
- package/contracts/test/TestService.sol +1 -1
- package/contracts/types/Amount.sol +109 -0
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +75 -0
- package/contracts/types/DistributorType.sol +2 -2
- package/contracts/types/Fee.sol +17 -8
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/ObjectType.sol +11 -6
- package/contracts/types/PayoutId.sol +82 -0
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +18 -11
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +7 -2
- package/contracts/types/Timestamp.sol +18 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -397
- 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/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +0 -448
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +0 -763
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -814
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +0 -442
- package/contracts/components/BaseComponent.sol +0 -159
- package/contracts/components/IBaseComponent.sol +0 -34
- 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/IInstanceBase.sol +0 -26
- package/contracts/instance/InstanceBase.sol +0 -41
- package/contracts/instance/base/ComponentServiceBase.sol +0 -82
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/service/ComponentOwnerService.sol +0 -315
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -0,0 +1,443 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRisk} from "../module/IRisk.sol";
|
5
|
+
import {IService} from "./IApplicationService.sol";
|
6
|
+
|
7
|
+
import {IComponents} from "../module/IComponents.sol";
|
8
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
9
|
+
import {IProductComponent} from "../../components/IProductComponent.sol";
|
10
|
+
import {Product} from "../../components/Product.sol";
|
11
|
+
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
12
|
+
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
13
|
+
import {IInstance} from "../IInstance.sol";
|
14
|
+
import {IPolicy} from "../module/IPolicy.sol";
|
15
|
+
import {IRisk} from "../module/IRisk.sol";
|
16
|
+
import {IBundle} from "../module/IBundle.sol";
|
17
|
+
import {IProductService} from "./IProductService.sol";
|
18
|
+
import {ITreasury} from "../module/ITreasury.sol";
|
19
|
+
import {ISetup} from "../module/ISetup.sol";
|
20
|
+
|
21
|
+
import {TokenHandler} from "../../shared/TokenHandler.sol";
|
22
|
+
|
23
|
+
import {IVersionable} from "../../shared/IVersionable.sol";
|
24
|
+
import {Versionable} from "../../shared/Versionable.sol";
|
25
|
+
|
26
|
+
import {Amount, AmountLib} from "../../types/Amount.sol";
|
27
|
+
import {Timestamp, TimestampLib, zeroTimestamp} from "../../types/Timestamp.sol";
|
28
|
+
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
29
|
+
import {Blocknumber, blockNumber} from "../../types/Blocknumber.sol";
|
30
|
+
import {ObjectType, INSTANCE, PRODUCT, POOL, APPLICATION, POLICY, CLAIM, BUNDLE} from "../../types/ObjectType.sol";
|
31
|
+
import {SUBMITTED, ACTIVE, KEEP_STATE, DECLINED, CONFIRMED, CLOSED, PAID} from "../../types/StateId.sol";
|
32
|
+
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
33
|
+
import {Fee, FeeLib} from "../../types/Fee.sol";
|
34
|
+
import {ReferralId} from "../../types/Referral.sol";
|
35
|
+
import {RiskId} from "../../types/RiskId.sol";
|
36
|
+
import {StateId} from "../../types/StateId.sol";
|
37
|
+
import {ClaimId, ClaimIdLib} from "../../types/ClaimId.sol";
|
38
|
+
import {PayoutId, PayoutIdLib} from "../../types/PayoutId.sol";
|
39
|
+
import {Version, VersionLib} from "../../types/Version.sol";
|
40
|
+
|
41
|
+
import {ComponentService} from "../base/ComponentService.sol";
|
42
|
+
import {InstanceReader} from "../InstanceReader.sol";
|
43
|
+
import {IBundleService} from "./IBundleService.sol";
|
44
|
+
import {IClaimService} from "./IClaimService.sol";
|
45
|
+
import {IPoolService} from "./IPoolService.sol";
|
46
|
+
import {IService} from "../../shared/IService.sol";
|
47
|
+
import {Service} from "../../shared/Service.sol";
|
48
|
+
|
49
|
+
|
50
|
+
contract ClaimService is
|
51
|
+
ComponentService,
|
52
|
+
IClaimService
|
53
|
+
{
|
54
|
+
|
55
|
+
IPoolService internal _poolService;
|
56
|
+
|
57
|
+
function _initialize(
|
58
|
+
address owner,
|
59
|
+
bytes memory data
|
60
|
+
)
|
61
|
+
internal
|
62
|
+
virtual override
|
63
|
+
initializer()
|
64
|
+
{
|
65
|
+
// TODO check this, might no longer be the way, refactor if necessary
|
66
|
+
address registryAddress;
|
67
|
+
address initialOwner;
|
68
|
+
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
69
|
+
|
70
|
+
initializeService(registryAddress, address(0), owner);
|
71
|
+
|
72
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getVersion().toMajorPart()));
|
73
|
+
|
74
|
+
registerInterface(type(IClaimService).interfaceId);
|
75
|
+
}
|
76
|
+
|
77
|
+
|
78
|
+
function getDomain() public pure override returns(ObjectType) {
|
79
|
+
return CLAIM();
|
80
|
+
}
|
81
|
+
|
82
|
+
function submit(
|
83
|
+
NftId policyNftId,
|
84
|
+
Amount claimAmount,
|
85
|
+
bytes memory claimData
|
86
|
+
)
|
87
|
+
external
|
88
|
+
virtual
|
89
|
+
returns (ClaimId claimId)
|
90
|
+
{
|
91
|
+
(
|
92
|
+
IInstance instance,
|
93
|
+
InstanceReader instanceReader,
|
94
|
+
IPolicy.PolicyInfo memory policyInfo
|
95
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
96
|
+
|
97
|
+
// check policy is in its active period
|
98
|
+
if(policyInfo.activatedAt.eqz() || TimestampLib.blockTimestamp() >= policyInfo.expiredAt) {
|
99
|
+
revert ErrorClaimServicePolicyNotOpen(policyNftId);
|
100
|
+
}
|
101
|
+
|
102
|
+
// check policy including this claim is still within sum insured
|
103
|
+
if(policyInfo.payoutAmount + claimAmount > policyInfo.sumInsuredAmount) {
|
104
|
+
revert ErrorClaimServiceClaimExceedsSumInsured(
|
105
|
+
policyNftId,
|
106
|
+
policyInfo.sumInsuredAmount,
|
107
|
+
AmountLib.toAmount(policyInfo.payoutAmount.toInt() + claimAmount.toInt()));
|
108
|
+
}
|
109
|
+
|
110
|
+
// create new claim
|
111
|
+
claimId = ClaimIdLib.toClaimId(policyInfo.claimsCount + 1);
|
112
|
+
instance.createClaim(
|
113
|
+
policyNftId,
|
114
|
+
claimId,
|
115
|
+
IPolicy.ClaimInfo(
|
116
|
+
claimAmount,
|
117
|
+
AmountLib.zero(), // paidAmount
|
118
|
+
0, // payoutsCount
|
119
|
+
0, // openPayoutsCount
|
120
|
+
claimData,
|
121
|
+
TimestampLib.zero())); // closedAt
|
122
|
+
|
123
|
+
// update and save policy info with instance
|
124
|
+
policyInfo.claimsCount += 1;
|
125
|
+
policyInfo.openClaimsCount += 1;
|
126
|
+
// policy claim amount is only updated when claim is confirmed
|
127
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
128
|
+
|
129
|
+
emit LogClaimServiceClaimSubmitted(policyNftId, claimId, claimAmount);
|
130
|
+
}
|
131
|
+
|
132
|
+
|
133
|
+
function confirm(
|
134
|
+
NftId policyNftId,
|
135
|
+
ClaimId claimId,
|
136
|
+
Amount confirmedAmount
|
137
|
+
)
|
138
|
+
external
|
139
|
+
virtual
|
140
|
+
{
|
141
|
+
(
|
142
|
+
IInstance instance,
|
143
|
+
InstanceReader instanceReader,
|
144
|
+
IPolicy.PolicyInfo memory policyInfo
|
145
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
146
|
+
|
147
|
+
// check/update claim info
|
148
|
+
IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, SUBMITTED());
|
149
|
+
claimInfo.claimAmount = confirmedAmount;
|
150
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, CONFIRMED());
|
151
|
+
|
152
|
+
// update and save policy info with instance
|
153
|
+
policyInfo.claimAmount = policyInfo.claimAmount.add(confirmedAmount);
|
154
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
155
|
+
|
156
|
+
emit LogClaimServiceClaimConfirmed(policyNftId, claimId, confirmedAmount);
|
157
|
+
}
|
158
|
+
|
159
|
+
function decline(
|
160
|
+
NftId policyNftId,
|
161
|
+
ClaimId claimId
|
162
|
+
)
|
163
|
+
external
|
164
|
+
virtual
|
165
|
+
{
|
166
|
+
(
|
167
|
+
IInstance instance,
|
168
|
+
InstanceReader instanceReader,
|
169
|
+
IPolicy.PolicyInfo memory policyInfo
|
170
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
171
|
+
|
172
|
+
// check/update claim info
|
173
|
+
IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, SUBMITTED());
|
174
|
+
claimInfo.closedAt = TimestampLib.blockTimestamp();
|
175
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, DECLINED());
|
176
|
+
|
177
|
+
// update and save policy info with instance
|
178
|
+
policyInfo.openClaimsCount -= 1;
|
179
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
180
|
+
|
181
|
+
emit LogClaimServiceClaimDeclined(policyNftId, claimId);
|
182
|
+
}
|
183
|
+
|
184
|
+
function close(
|
185
|
+
NftId policyNftId,
|
186
|
+
ClaimId claimId
|
187
|
+
)
|
188
|
+
external
|
189
|
+
virtual
|
190
|
+
{
|
191
|
+
(
|
192
|
+
IInstance instance,
|
193
|
+
InstanceReader instanceReader,
|
194
|
+
IPolicy.PolicyInfo memory policyInfo
|
195
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
196
|
+
|
197
|
+
// check/update claim info
|
198
|
+
IPolicy.ClaimInfo memory claimInfo = _verifyClaim(instanceReader, policyNftId, claimId, CONFIRMED());
|
199
|
+
|
200
|
+
// check claim has no open payouts
|
201
|
+
if(claimInfo.openPayoutsCount > 0) {
|
202
|
+
revert ErrorClaimServiceClaimWithOpenPayouts(
|
203
|
+
policyNftId,
|
204
|
+
claimId,
|
205
|
+
claimInfo.openPayoutsCount);
|
206
|
+
}
|
207
|
+
|
208
|
+
// check claim paid amount matches with claim amount
|
209
|
+
if(claimInfo.paidAmount.toInt() < claimInfo.claimAmount.toInt()) {
|
210
|
+
revert ErrorClaimServiceClaimWithMissingPayouts(
|
211
|
+
policyNftId,
|
212
|
+
claimId,
|
213
|
+
claimInfo.claimAmount,
|
214
|
+
claimInfo.paidAmount);
|
215
|
+
}
|
216
|
+
|
217
|
+
claimInfo.closedAt = TimestampLib.blockTimestamp();
|
218
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, CLOSED());
|
219
|
+
|
220
|
+
// update and save policy info with instance
|
221
|
+
policyInfo.openClaimsCount -= 1;
|
222
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
223
|
+
|
224
|
+
emit LogClaimServiceClaimClosed(policyNftId, claimId);
|
225
|
+
}
|
226
|
+
|
227
|
+
|
228
|
+
function createPayout(
|
229
|
+
NftId policyNftId,
|
230
|
+
ClaimId claimId,
|
231
|
+
Amount amount,
|
232
|
+
bytes memory data
|
233
|
+
)
|
234
|
+
external
|
235
|
+
returns (PayoutId payoutId)
|
236
|
+
{
|
237
|
+
(
|
238
|
+
IInstance instance,
|
239
|
+
InstanceReader instanceReader,
|
240
|
+
IPolicy.PolicyInfo memory policyInfo
|
241
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
242
|
+
|
243
|
+
IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
244
|
+
StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
|
245
|
+
|
246
|
+
// TODO add checks
|
247
|
+
// claim needs to be open
|
248
|
+
// claim.paidAmount + amount <= claim.claimAmount
|
249
|
+
|
250
|
+
// check/update claim info
|
251
|
+
// create payout info with instance
|
252
|
+
uint8 claimNo = claimInfo.payoutsCount + 1;
|
253
|
+
payoutId = PayoutIdLib.toPayoutId(claimId, claimNo);
|
254
|
+
instance.createPayout(
|
255
|
+
policyNftId,
|
256
|
+
payoutId,
|
257
|
+
IPolicy.PayoutInfo(
|
258
|
+
payoutId.toClaimId(),
|
259
|
+
amount,
|
260
|
+
data,
|
261
|
+
TimestampLib.zero()));
|
262
|
+
|
263
|
+
// update and save claim info with instance
|
264
|
+
claimInfo.payoutsCount += 1;
|
265
|
+
claimInfo.openPayoutsCount += 1;
|
266
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
|
267
|
+
|
268
|
+
// update and save policy info with instance
|
269
|
+
policyInfo.payoutAmount.add(amount);
|
270
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
271
|
+
|
272
|
+
emit LogClaimServicePayoutCreated(policyNftId, payoutId, amount);
|
273
|
+
}
|
274
|
+
|
275
|
+
|
276
|
+
function processPayout(
|
277
|
+
NftId policyNftId,
|
278
|
+
PayoutId payoutId
|
279
|
+
)
|
280
|
+
external
|
281
|
+
virtual
|
282
|
+
{
|
283
|
+
(
|
284
|
+
IInstance instance,
|
285
|
+
InstanceReader instanceReader,
|
286
|
+
IPolicy.PolicyInfo memory policyInfo
|
287
|
+
) = _verifyCallerWithPolicy(policyNftId);
|
288
|
+
|
289
|
+
// TODO add check that payout exists and is open
|
290
|
+
IPolicy.PayoutInfo memory payoutInfo = instanceReader.getPayoutInfo(policyNftId, payoutId);
|
291
|
+
|
292
|
+
// update and save payout info with instance
|
293
|
+
payoutInfo.paidAt = TimestampLib.blockTimestamp();
|
294
|
+
instance.updatePayout(policyNftId, payoutId, payoutInfo, PAID());
|
295
|
+
|
296
|
+
// TODO update and save claim info with instance
|
297
|
+
ClaimId claimId = payoutId.toClaimId();
|
298
|
+
Amount payoutAmount = payoutInfo.amount;
|
299
|
+
IPolicy.ClaimInfo memory claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
300
|
+
claimInfo.paidAmount = claimInfo.paidAmount.add(payoutAmount);
|
301
|
+
claimInfo.openPayoutsCount -= 1;
|
302
|
+
|
303
|
+
// check if this payout is closing the linked claim
|
304
|
+
// update claim and policy info accordingly
|
305
|
+
if(claimInfo.openPayoutsCount == 0 && claimInfo.paidAmount == claimInfo.claimAmount) {
|
306
|
+
claimInfo.closedAt == TimestampLib.blockTimestamp();
|
307
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, CLOSED());
|
308
|
+
|
309
|
+
policyInfo.openClaimsCount -= 1;
|
310
|
+
} else {
|
311
|
+
instance.updateClaim(policyNftId, claimId, claimInfo, KEEP_STATE());
|
312
|
+
}
|
313
|
+
|
314
|
+
// update and save policy info with instance
|
315
|
+
policyInfo.payoutAmount = policyInfo.payoutAmount.add(payoutAmount);
|
316
|
+
instance.updatePolicyClaims(policyNftId, policyInfo, KEEP_STATE());
|
317
|
+
|
318
|
+
// inform pool about payout
|
319
|
+
_poolService.reduceCollateral(instance, policyNftId, policyInfo, payoutAmount);
|
320
|
+
|
321
|
+
// transfer payout token and fee
|
322
|
+
(
|
323
|
+
Amount netPayoutAmount,
|
324
|
+
address beneficiary
|
325
|
+
) = _transferPayoutAmount(
|
326
|
+
instanceReader,
|
327
|
+
policyNftId,
|
328
|
+
policyInfo,
|
329
|
+
payoutInfo);
|
330
|
+
|
331
|
+
// TODO callback IPolicyHolder
|
332
|
+
|
333
|
+
emit LogClaimServicePayoutProcessed(policyNftId, payoutId, payoutAmount, beneficiary, netPayoutAmount);
|
334
|
+
}
|
335
|
+
|
336
|
+
// TODO create (I)TreasuryService that deals with all gif related token transfers
|
337
|
+
function _transferPayoutAmount(
|
338
|
+
InstanceReader instanceReader,
|
339
|
+
NftId policyNftId,
|
340
|
+
IPolicy.PolicyInfo memory policyInfo,
|
341
|
+
IPolicy.PayoutInfo memory payoutInfo
|
342
|
+
)
|
343
|
+
internal
|
344
|
+
returns (
|
345
|
+
Amount netPayoutAmount,
|
346
|
+
address beneficiary
|
347
|
+
)
|
348
|
+
{
|
349
|
+
Amount payoutAmount = payoutInfo.amount;
|
350
|
+
|
351
|
+
if(payoutAmount.gtz()) {
|
352
|
+
NftId productNftId = policyInfo.productNftId;
|
353
|
+
ISetup.ProductSetupInfo memory setupInfo = instanceReader.getProductSetupInfo(productNftId);
|
354
|
+
|
355
|
+
// get pool component info from policy or product
|
356
|
+
NftId poolNftId = getRegistry().getObjectInfo(policyInfo.bundleNftId).parentNftId;
|
357
|
+
IComponents.ComponentInfo memory poolInfo = instanceReader.getComponentInfo(poolNftId);
|
358
|
+
|
359
|
+
netPayoutAmount = payoutAmount;
|
360
|
+
beneficiary = _getBeneficiary(policyNftId, payoutInfo.claimId);
|
361
|
+
|
362
|
+
if(FeeLib.gtz(setupInfo.processingFee)) {
|
363
|
+
// TODO calculate net payout and processing fees
|
364
|
+
// TODO transfer processing fees to product wallet
|
365
|
+
// TODO inform product to update fee book keeping
|
366
|
+
}
|
367
|
+
|
368
|
+
poolInfo.tokenHandler.transfer(
|
369
|
+
poolInfo.wallet,
|
370
|
+
beneficiary,
|
371
|
+
netPayoutAmount);
|
372
|
+
}
|
373
|
+
}
|
374
|
+
|
375
|
+
// internal functions
|
376
|
+
|
377
|
+
function _getBeneficiary(
|
378
|
+
NftId policyNftId,
|
379
|
+
ClaimId claimId
|
380
|
+
)
|
381
|
+
internal
|
382
|
+
returns (address beneficiary)
|
383
|
+
{
|
384
|
+
// TODO check if owner is IPolicyHolder
|
385
|
+
// if so, obtain beneficiary from this contract
|
386
|
+
|
387
|
+
// default beneficiary is policy nft owner
|
388
|
+
beneficiary = getRegistry().ownerOf(policyNftId);
|
389
|
+
}
|
390
|
+
|
391
|
+
|
392
|
+
function _verifyCallerWithPolicy(
|
393
|
+
NftId policyNftId
|
394
|
+
)
|
395
|
+
internal
|
396
|
+
returns (
|
397
|
+
IInstance instance,
|
398
|
+
InstanceReader instanceReader,
|
399
|
+
IPolicy.PolicyInfo memory policyInfo
|
400
|
+
)
|
401
|
+
{
|
402
|
+
NftId productNftId;
|
403
|
+
(productNftId,, instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
404
|
+
instanceReader = instance.getInstanceReader();
|
405
|
+
|
406
|
+
// check caller(product) policy match
|
407
|
+
policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
408
|
+
if(policyInfo.productNftId != productNftId) {
|
409
|
+
revert ErrorClaimServicePolicyProductMismatch(policyNftId,
|
410
|
+
policyInfo.productNftId,
|
411
|
+
productNftId);
|
412
|
+
}
|
413
|
+
}
|
414
|
+
|
415
|
+
function _verifyClaim(
|
416
|
+
InstanceReader instanceReader,
|
417
|
+
NftId policyNftId,
|
418
|
+
ClaimId claimId,
|
419
|
+
StateId expectedState
|
420
|
+
)
|
421
|
+
internal
|
422
|
+
view
|
423
|
+
returns (
|
424
|
+
IPolicy.ClaimInfo memory claimInfo
|
425
|
+
)
|
426
|
+
{
|
427
|
+
// check claim is created state
|
428
|
+
StateId claimState = instanceReader.getClaimState(policyNftId, claimId);
|
429
|
+
if(claimState != expectedState) {
|
430
|
+
revert ErrorClaimServiceClaimNotInExpectedState(
|
431
|
+
policyNftId, claimId, expectedState, claimState);
|
432
|
+
}
|
433
|
+
|
434
|
+
// get claim info
|
435
|
+
claimInfo = instanceReader.getClaimInfo(policyNftId, claimId);
|
436
|
+
}
|
437
|
+
|
438
|
+
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
439
|
+
IRegistry.ObjectInfo memory productInfo;
|
440
|
+
(, productInfo,) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
441
|
+
product = Product(productInfo.objectAddress);
|
442
|
+
}
|
443
|
+
}
|
@@ -0,0 +1,35 @@
|
|
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 {ClaimService} from "./ClaimService.sol";
|
7
|
+
|
8
|
+
contract ClaimServiceManager is ProxyManager {
|
9
|
+
|
10
|
+
ClaimService private _claimService;
|
11
|
+
|
12
|
+
/// @dev initializes proxy manager with service implementation
|
13
|
+
constructor(
|
14
|
+
address registryAddress
|
15
|
+
)
|
16
|
+
ProxyManager(registryAddress)
|
17
|
+
{
|
18
|
+
ClaimService svc = new ClaimService();
|
19
|
+
bytes memory data = abi.encode(registryAddress, address(this));
|
20
|
+
IVersionable versionable = deploy(
|
21
|
+
address(svc),
|
22
|
+
data);
|
23
|
+
|
24
|
+
_claimService = ClaimService(address(versionable));
|
25
|
+
}
|
26
|
+
|
27
|
+
//--- view functions ----------------------------------------------------//
|
28
|
+
function getClaimService()
|
29
|
+
external
|
30
|
+
view
|
31
|
+
returns (ClaimService)
|
32
|
+
{
|
33
|
+
return _claimService;
|
34
|
+
}
|
35
|
+
}
|