@etherisc/gif-next 0.0.2-d3ee0cc-268 → 0.0.2-d48ae55-246
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 +314 -11
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +897 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +1433 -0
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{registry/IChainNft.sol/IChainNft.json → components/IComponent.sol/IComponent.json} +292 -224
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +950 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +614 -76
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +594 -60
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +1138 -159
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +1084 -99
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +66 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +24 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +42 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +2 -2
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +2 -2
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +1 -1
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +2 -2
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +764 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +185 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1539 -1018
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +674 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2262 -1095
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +984 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1386 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1260 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +610 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +261 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +754 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +45 -127
- 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 +55 -245
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +4 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +254 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{bundle/IBundle.sol → IBundle.sol}/IBundle.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{access/IAccess.sol/IAccess.json → IDistribution.sol/IDistribution.json} +2 -2
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{policy/IPolicy.sol → IPolicy.sol}/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{risk/IRisk.sol → IRisk.sol}/IRisk.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{base/ModuleBase.sol/ModuleBase.json → module/ISetup.sol/ISetup.json} +2 -2
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/{treasury/ITreasury.sol → ITreasury.sol}/ITreasury.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +1117 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1318 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +586 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1200 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +614 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +638 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +798 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +656 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +784 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +208 -72
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +217 -145
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1378 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +642 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +570 -84
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +574 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +546 -212
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +574 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +186 -12
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +466 -34
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +1055 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +34 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +470 -103
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1407 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +601 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +531 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
- 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 +4 -0
- package/artifacts/contracts/{components/IBaseComponent.sol/IBaseComponent.json → shared/INftOwnable.sol/INftOwnable.json} +62 -72
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +125 -32
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +69 -0
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/{instance/service/IComponentOwnerService.sol/IComponentOwnerService.json → shared/IService.sol/IService.json} +181 -111
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +55 -14
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +303 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +269 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +499 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +318 -24
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +105 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/shared/Service.sol/Service.json +627 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +78 -14
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +4 -4
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +333 -24
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +44 -10
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +436 -56
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +91 -53
- 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 +103 -23
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/test/Usdc.sol/USDC.json +91 -53
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +52 -13
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +31 -17
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
- 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/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +123 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +86 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +156 -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 +15 -2
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/{UFixedMathLib.json → UFixedLib.json} +3 -3
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +40 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +22 -3
- package/contracts/components/Component.sol +236 -0
- package/contracts/components/Distribution.sol +316 -0
- package/contracts/components/IComponent.sol +50 -0
- package/contracts/components/IDistributionComponent.sol +100 -0
- package/contracts/components/IPoolComponent.sol +65 -35
- package/contracts/components/IProductComponent.sol +29 -9
- package/contracts/components/Pool.sol +180 -100
- package/contracts/components/Product.sol +203 -42
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/instance/BundleManager.sol +125 -0
- package/contracts/instance/Cloneable.sol +46 -0
- package/contracts/instance/IInstance.sol +79 -45
- package/contracts/instance/IInstanceService.sol +59 -0
- package/contracts/instance/Instance.sol +266 -53
- package/contracts/instance/InstanceAccessManager.sol +297 -0
- package/contracts/instance/InstanceReader.sol +293 -0
- package/contracts/instance/InstanceService.sol +442 -0
- package/contracts/instance/InstanceServiceManager.sol +54 -0
- package/contracts/instance/ObjectManager.sol +84 -0
- package/contracts/instance/base/ComponentService.sol +134 -0
- package/contracts/instance/base/IKeyValueStore.sol +13 -13
- package/contracts/instance/base/ILifecycle.sol +3 -3
- package/contracts/instance/base/KeyValueStore.sol +53 -37
- package/contracts/instance/base/Lifecycle.sol +16 -11
- package/contracts/instance/module/IAccess.sol +47 -0
- package/contracts/instance/module/IBundle.sol +20 -0
- package/contracts/instance/module/IDistribution.sol +39 -0
- package/contracts/instance/module/IPolicy.sol +45 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +47 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/ApplicationService.sol +268 -0
- package/contracts/instance/service/BundleService.sol +298 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/DistributionService.sol +291 -0
- package/contracts/instance/service/DistributionServiceManager.sol +51 -0
- package/contracts/instance/service/IApplicationService.sol +82 -0
- package/contracts/instance/service/IBundleService.sol +54 -0
- package/contracts/instance/service/IDistributionService.sol +65 -0
- package/contracts/instance/service/IPolicyService.sol +88 -0
- package/contracts/instance/service/IPoolService.sol +8 -18
- package/contracts/instance/service/IProductService.sol +21 -39
- package/contracts/instance/service/PolicyService.sol +524 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +78 -92
- package/contracts/instance/service/PoolServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +168 -289
- package/contracts/instance/service/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +79 -36
- package/contracts/registry/IRegistry.sol +66 -24
- package/contracts/registry/IRegistryService.sol +67 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +366 -283
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +277 -0
- package/contracts/registry/RegistryServiceManager.sol +62 -0
- package/contracts/registry/ReleaseManager.sol +331 -0
- package/contracts/registry/TokenRegistry.sol +113 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/ERC165.sol +13 -8
- package/contracts/shared/INftOwnable.sol +28 -0
- package/contracts/shared/IPolicyHolder.sol +26 -0
- package/contracts/shared/IRegisterable.sol +10 -19
- package/contracts/shared/IRegistryLinked.sol +15 -0
- package/contracts/shared/IService.sol +16 -0
- package/contracts/shared/IVersionable.sol +55 -11
- package/contracts/shared/NftOwnable.sol +190 -0
- package/contracts/shared/PolicyHolder.sol +81 -0
- package/contracts/shared/ProxyManager.sol +95 -0
- package/contracts/shared/Registerable.sol +58 -63
- package/contracts/shared/RegistryLinked.sol +64 -0
- package/contracts/shared/Service.sol +60 -0
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +113 -54
- package/contracts/test/TestFee.sol +2 -2
- package/contracts/test/TestRegisterable.sol +5 -6
- package/contracts/test/TestRoleId.sol +2 -2
- package/contracts/test/TestService.sol +7 -14
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +10 -5
- package/contracts/types/Key32.sol +8 -3
- package/contracts/types/NftIdSet.sol +26 -24
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +55 -14
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +65 -11
- package/contracts/types/StateId.sol +5 -1
- package/contracts/types/Timestamp.sol +7 -3
- package/contracts/types/UFixed.sol +128 -12
- package/contracts/types/Version.sol +13 -1
- package/package.json +6 -5
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -174
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.json +0 -24
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +0 -300
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -63
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IService.sol/IService.json +0 -300
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.json +0 -326
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +0 -300
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.json +0 -333
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.json +0 -333
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +0 -296
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +0 -296
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.json +0 -10
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.json +0 -10
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.json +0 -10
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +0 -188
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.json +0 -10
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.json +0 -188
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.json +0 -261
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.json +0 -261
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.json +0 -10
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.json +0 -149
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.json +0 -149
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +0 -10
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +0 -10
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.json +0 -533
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +0 -76
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.json +0 -533
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -491
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +0 -24
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.json +0 -24
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +0 -4
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +0 -387
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +0 -4
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +0 -393
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -88
- package/contracts/components/IBaseComponent.sol +0 -19
- package/contracts/experiment/statemachine/README.md +0 -112
- package/contracts/instance/IInstanceLinked.sol +0 -8
- package/contracts/instance/base/ComponentServiceBase.sol +0 -42
- package/contracts/instance/base/IInstanceBase.sol +0 -14
- package/contracts/instance/base/IService.sol +0 -15
- package/contracts/instance/base/InstanceBase.sol +0 -80
- package/contracts/instance/base/ModuleBase.sol +0 -52
- package/contracts/instance/base/ServiceBase.sol +0 -37
- package/contracts/instance/module/access/Access.sol +0 -149
- package/contracts/instance/module/access/IAccess.sol +0 -53
- package/contracts/instance/module/bundle/BundleModule.sol +0 -136
- package/contracts/instance/module/bundle/IBundle.sol +0 -58
- package/contracts/instance/module/compensation/CompensationModule.sol +0 -8
- package/contracts/instance/module/compensation/ICompensation.sol +0 -10
- package/contracts/instance/module/component/ComponentModule.sol +0 -95
- package/contracts/instance/module/component/IComponent.sol +0 -53
- package/contracts/instance/module/policy/IPolicy.sol +0 -60
- package/contracts/instance/module/policy/PolicyModule.sol +0 -76
- package/contracts/instance/module/pool/IPoolModule.sol +0 -41
- package/contracts/instance/module/pool/PoolModule.sol +0 -87
- package/contracts/instance/module/risk/IRisk.sol +0 -10
- package/contracts/instance/module/risk/RiskModule.sol +0 -8
- package/contracts/instance/module/treasury/ITreasury.sol +0 -103
- package/contracts/instance/module/treasury/TokenHandler.sol +0 -48
- package/contracts/instance/module/treasury/TreasuryModule.sol +0 -152
- package/contracts/instance/service/ComponentOwnerService.sol +0 -170
- package/contracts/instance/service/IComponentOwnerService.sol +0 -22
- package/contracts/registry/IChainNft.sol +0 -21
- package/contracts/registry/IRegistryLinked.sol +0 -8
- package/contracts/shared/IOwnable.sol +0 -6
- package/contracts/test/TestPool.sol +0 -22
- package/contracts/test/TestProduct.sol +0 -44
@@ -1,58 +1,40 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
+
import {IRisk} from "../module/IRisk.sol";
|
5
|
+
import {IService} from "../../shared/IService.sol";
|
6
|
+
|
4
7
|
import {NftId} from "../../types/NftId.sol";
|
8
|
+
import {ReferralId} from "../../types/Referral.sol";
|
9
|
+
import {RiskId} from "../../types/RiskId.sol";
|
10
|
+
import {StateId} from "../../types/StateId.sol";
|
5
11
|
import {Timestamp} from "../../types/Timestamp.sol";
|
6
12
|
import {UFixed} from "../../types/UFixed.sol";
|
7
13
|
import {Fee} from "../../types/Fee.sol";
|
8
|
-
import {IService} from "../base/IService.sol";
|
9
14
|
|
10
15
|
interface IProductService is IService {
|
16
|
+
|
17
|
+
function register(address productAddress) external returns(NftId);
|
18
|
+
|
11
19
|
function setFees(
|
12
|
-
Fee memory
|
20
|
+
Fee memory productFee,
|
13
21
|
Fee memory processingFee
|
14
22
|
) external;
|
15
23
|
|
16
|
-
function
|
17
|
-
|
18
|
-
|
19
|
-
uint256 premiumAmount,
|
20
|
-
uint256 lifetime,
|
21
|
-
NftId bundleNftId
|
22
|
-
) external returns (NftId nftId);
|
23
|
-
|
24
|
-
// function revoke(unit256 nftId) external;
|
25
|
-
|
26
|
-
/**
|
27
|
-
* @dev underwrites the policy represented by {policyNftId}.
|
28
|
-
* optionally collects premiums and activates the policy.
|
29
|
-
* - premium payment is only attempted if requirePremiumPayment is set to true
|
30
|
-
* - activation is only done if activateAt is a non-zero timestamp
|
31
|
-
*/
|
32
|
-
function underwrite(
|
33
|
-
NftId policyNftId,
|
34
|
-
bool requirePremiumPayment,
|
35
|
-
Timestamp activateAt
|
24
|
+
function createRisk(
|
25
|
+
RiskId riskId,
|
26
|
+
bytes memory data
|
36
27
|
) external;
|
37
28
|
|
38
|
-
// function decline(uint256 nftId) external;
|
39
|
-
// function expire(uint256 nftId) external;
|
40
|
-
|
41
|
-
function collectPremium(NftId nftId, Timestamp activateAt) external;
|
42
|
-
|
43
|
-
function activate(NftId nftId, Timestamp activateAt) external;
|
44
29
|
|
30
|
+
function updateRisk(
|
31
|
+
RiskId riskId,
|
32
|
+
bytes memory data
|
33
|
+
) external;
|
45
34
|
|
46
|
-
function close(NftId nftId) external;
|
47
|
-
|
48
|
-
// function createClaim(uint256 nftId, uint256 claimAmount) external;
|
49
|
-
// function confirmClaim(uint256 nftId, uint256 claimId, uint256 claimAmount) external;
|
50
|
-
// function declineClaim(uint256 nftId, uint256 claimId) external;
|
51
|
-
// function closeClaim(uint256 nftId, uint256 claimId) external;
|
52
|
-
|
53
|
-
function calculateRequiredCollateral(
|
54
|
-
UFixed collateralizationLevel,
|
55
|
-
uint256 sumInsuredAmount
|
56
|
-
) external pure returns(uint256 collateralAmount);
|
57
35
|
|
36
|
+
function updateRiskState(
|
37
|
+
RiskId riskId,
|
38
|
+
StateId newState
|
39
|
+
) external;
|
58
40
|
}
|
@@ -0,0 +1,524 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
+
import {IProductComponent} from "../../components/IProductComponent.sol";
|
6
|
+
import {Product} from "../../components/Product.sol";
|
7
|
+
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
8
|
+
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
9
|
+
import {IInstance} from "../IInstance.sol";
|
10
|
+
import {IPolicy} from "../module/IPolicy.sol";
|
11
|
+
import {IRisk} from "../module/IRisk.sol";
|
12
|
+
import {IBundle} from "../module/IBundle.sol";
|
13
|
+
import {IProductService} from "./IProductService.sol";
|
14
|
+
import {ITreasury} from "../module/ITreasury.sol";
|
15
|
+
import {ISetup} from "../module/ISetup.sol";
|
16
|
+
|
17
|
+
import {TokenHandler} from "../../shared/TokenHandler.sol";
|
18
|
+
|
19
|
+
import {IVersionable} from "../../shared/IVersionable.sol";
|
20
|
+
import {Versionable} from "../../shared/Versionable.sol";
|
21
|
+
|
22
|
+
import {Timestamp, TimestampLib, zeroTimestamp} from "../../types/Timestamp.sol";
|
23
|
+
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
24
|
+
import {Blocknumber, blockNumber} from "../../types/Blocknumber.sol";
|
25
|
+
import {ObjectType, INSTANCE, PRODUCT, POOL, POLICY, BUNDLE} from "../../types/ObjectType.sol";
|
26
|
+
import {APPLIED, UNDERWRITTEN, ACTIVE, KEEP_STATE, CLOSED} from "../../types/StateId.sol";
|
27
|
+
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
28
|
+
import {Fee, FeeLib} from "../../types/Fee.sol";
|
29
|
+
import {ReferralId} from "../../types/Referral.sol";
|
30
|
+
import {RiskId} from "../../types/RiskId.sol";
|
31
|
+
import {StateId} from "../../types/StateId.sol";
|
32
|
+
import {Version, VersionLib} from "../../types/Version.sol";
|
33
|
+
//import {RoleId, PRODUCT_OWNER_ROLE} from "../../types/RoleId.sol";
|
34
|
+
|
35
|
+
import {IService} from "../../shared/IService.sol";
|
36
|
+
import {Service} from "../../shared/Service.sol";
|
37
|
+
import {ComponentService} from "../base/ComponentService.sol";
|
38
|
+
import {IPolicyService} from "./IPolicyService.sol";
|
39
|
+
import {InstanceReader} from "../InstanceReader.sol";
|
40
|
+
import {IPoolService} from "./IPoolService.sol";
|
41
|
+
import {IBundleService} from "./IBundleService.sol";
|
42
|
+
|
43
|
+
|
44
|
+
contract PolicyService is
|
45
|
+
ComponentService,
|
46
|
+
IPolicyService
|
47
|
+
{
|
48
|
+
using NftIdLib for NftId;
|
49
|
+
using TimestampLib for Timestamp;
|
50
|
+
|
51
|
+
IPoolService internal _poolService;
|
52
|
+
IBundleService internal _bundleService;
|
53
|
+
|
54
|
+
event LogProductServiceSender(address sender);
|
55
|
+
|
56
|
+
function _initialize(
|
57
|
+
address owner,
|
58
|
+
bytes memory data
|
59
|
+
)
|
60
|
+
internal
|
61
|
+
initializer
|
62
|
+
virtual override
|
63
|
+
{
|
64
|
+
address registryAddress;
|
65
|
+
address initialOwner;
|
66
|
+
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
67
|
+
|
68
|
+
initializeService(registryAddress, owner);
|
69
|
+
|
70
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getMajorVersion()));
|
71
|
+
_bundleService = IBundleService(getRegistry().getServiceAddress(BUNDLE(), getMajorVersion()));
|
72
|
+
|
73
|
+
registerInterface(type(IPolicyService).interfaceId);
|
74
|
+
}
|
75
|
+
|
76
|
+
|
77
|
+
function getDomain() public pure override(IService, Service) returns(ObjectType) {
|
78
|
+
return POLICY();
|
79
|
+
}
|
80
|
+
|
81
|
+
|
82
|
+
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
83
|
+
IRegistry.ObjectInfo memory productInfo;
|
84
|
+
(productInfo,) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
85
|
+
product = Product(productInfo.objectAddress);
|
86
|
+
}
|
87
|
+
|
88
|
+
// TODO: no access restrictions
|
89
|
+
function calculatePremium(
|
90
|
+
RiskId riskId,
|
91
|
+
uint256 sumInsuredAmount,
|
92
|
+
uint256 lifetime,
|
93
|
+
bytes memory applicationData,
|
94
|
+
NftId bundleNftId,
|
95
|
+
ReferralId referralId
|
96
|
+
)
|
97
|
+
public
|
98
|
+
view
|
99
|
+
virtual override
|
100
|
+
returns (
|
101
|
+
uint256 premiumAmount,
|
102
|
+
uint256 productFeeAmount,
|
103
|
+
uint256 poolFeeAmount,
|
104
|
+
uint256 bundleFeeAmount,
|
105
|
+
uint256 distributionFeeAmount
|
106
|
+
)
|
107
|
+
{
|
108
|
+
Product product = _getAndVerifyInstanceAndProduct();
|
109
|
+
uint256 netPremiumAmount = product.calculateNetPremium(
|
110
|
+
sumInsuredAmount,
|
111
|
+
riskId,
|
112
|
+
lifetime,
|
113
|
+
applicationData
|
114
|
+
);
|
115
|
+
|
116
|
+
(
|
117
|
+
productFeeAmount,
|
118
|
+
poolFeeAmount,
|
119
|
+
bundleFeeAmount,
|
120
|
+
distributionFeeAmount
|
121
|
+
) = _calculateFeeAmounts(
|
122
|
+
netPremiumAmount,
|
123
|
+
product,
|
124
|
+
bundleNftId,
|
125
|
+
referralId
|
126
|
+
);
|
127
|
+
|
128
|
+
premiumAmount = netPremiumAmount + productFeeAmount;
|
129
|
+
premiumAmount += poolFeeAmount + bundleFeeAmount;
|
130
|
+
premiumAmount += distributionFeeAmount;
|
131
|
+
}
|
132
|
+
|
133
|
+
function _calculateFeeAmounts(
|
134
|
+
uint256 netPremiumAmount,
|
135
|
+
Product product,
|
136
|
+
NftId bundleNftId,
|
137
|
+
ReferralId referralId
|
138
|
+
)
|
139
|
+
internal
|
140
|
+
view
|
141
|
+
returns (
|
142
|
+
uint256 productFeeAmount,
|
143
|
+
uint256 poolFeeAmount,
|
144
|
+
uint256 bundleFeeAmount,
|
145
|
+
uint256 distributionFeeAmount
|
146
|
+
)
|
147
|
+
{
|
148
|
+
InstanceReader instanceReader;
|
149
|
+
{
|
150
|
+
IInstance instance = product.getInstance();
|
151
|
+
instanceReader = instance.getInstanceReader();
|
152
|
+
}
|
153
|
+
|
154
|
+
NftId poolNftId = product.getPoolNftId();
|
155
|
+
IBundle.BundleInfo memory bundleInfo = instanceReader.getBundleInfo(bundleNftId);
|
156
|
+
require(bundleInfo.poolNftId == poolNftId,"ERROR:PRS-035:BUNDLE_POOL_MISMATCH");
|
157
|
+
|
158
|
+
{
|
159
|
+
ISetup.ProductSetupInfo memory productSetupInfo = instanceReader.getProductSetupInfo(product.getProductNftId());
|
160
|
+
(productFeeAmount,) = FeeLib.calculateFee(productSetupInfo.productFee, netPremiumAmount);
|
161
|
+
}
|
162
|
+
{
|
163
|
+
ISetup.PoolSetupInfo memory poolSetupInfo = instanceReader.getPoolSetupInfo(poolNftId);
|
164
|
+
(poolFeeAmount,) = FeeLib.calculateFee(poolSetupInfo.poolFee, netPremiumAmount);
|
165
|
+
}
|
166
|
+
{
|
167
|
+
NftId distributionNftId = product.getDistributionNftId();
|
168
|
+
ISetup.DistributionSetupInfo memory distributionSetupInfo = instanceReader.getDistributionSetupInfo(distributionNftId);
|
169
|
+
(distributionFeeAmount,) = FeeLib.calculateFee(distributionSetupInfo.distributionFee, netPremiumAmount);
|
170
|
+
}
|
171
|
+
|
172
|
+
(bundleFeeAmount,) = FeeLib.calculateFee(bundleInfo.fee, netPremiumAmount);
|
173
|
+
}
|
174
|
+
|
175
|
+
|
176
|
+
function createApplication(
|
177
|
+
address applicationOwner,
|
178
|
+
RiskId riskId,
|
179
|
+
uint256 sumInsuredAmount,
|
180
|
+
uint256 lifetime,
|
181
|
+
bytes memory applicationData,
|
182
|
+
NftId bundleNftId,
|
183
|
+
ReferralId referralId
|
184
|
+
)
|
185
|
+
external
|
186
|
+
virtual override
|
187
|
+
returns (NftId policyNftId)
|
188
|
+
{
|
189
|
+
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
190
|
+
// TODO: add validations (see create bundle in pool service)
|
191
|
+
|
192
|
+
policyNftId = getRegistryService().registerPolicy(
|
193
|
+
IRegistry.ObjectInfo(
|
194
|
+
zeroNftId(),
|
195
|
+
productInfo.nftId,
|
196
|
+
POLICY(),
|
197
|
+
false, // intercepting property for policies is defined on product
|
198
|
+
address(0),
|
199
|
+
applicationOwner,
|
200
|
+
""
|
201
|
+
)
|
202
|
+
);
|
203
|
+
|
204
|
+
(uint256 premiumAmount,,,,) = calculatePremium(
|
205
|
+
riskId,
|
206
|
+
sumInsuredAmount,
|
207
|
+
lifetime,
|
208
|
+
applicationData,
|
209
|
+
bundleNftId,
|
210
|
+
referralId
|
211
|
+
);
|
212
|
+
|
213
|
+
IPolicy.PolicyInfo memory policyInfo = IPolicy.PolicyInfo(
|
214
|
+
productInfo.nftId,
|
215
|
+
bundleNftId,
|
216
|
+
referralId,
|
217
|
+
riskId,
|
218
|
+
sumInsuredAmount,
|
219
|
+
premiumAmount,
|
220
|
+
0,
|
221
|
+
lifetime,
|
222
|
+
applicationData,
|
223
|
+
"",
|
224
|
+
0,
|
225
|
+
0,
|
226
|
+
0,
|
227
|
+
zeroTimestamp(),
|
228
|
+
zeroTimestamp(),
|
229
|
+
zeroTimestamp()
|
230
|
+
);
|
231
|
+
|
232
|
+
instance.createPolicy(policyNftId, policyInfo);
|
233
|
+
instance.updatePolicyState(policyNftId, APPLIED());
|
234
|
+
|
235
|
+
// TODO: add logging
|
236
|
+
}
|
237
|
+
|
238
|
+
function _getAndVerifyUnderwritingSetup(
|
239
|
+
IInstance instance,
|
240
|
+
InstanceReader instanceReader,
|
241
|
+
IPolicy.PolicyInfo memory policyInfo,
|
242
|
+
ISetup.ProductSetupInfo memory productSetupInfo
|
243
|
+
)
|
244
|
+
internal
|
245
|
+
view
|
246
|
+
returns (
|
247
|
+
NftId poolNftId,
|
248
|
+
NftId bundleNftId,
|
249
|
+
IBundle.BundleInfo memory bundleInfo,
|
250
|
+
uint256 collateralAmount
|
251
|
+
)
|
252
|
+
{
|
253
|
+
// check match between policy and bundle (via pool)
|
254
|
+
poolNftId = productSetupInfo.poolNftId;
|
255
|
+
bundleNftId = policyInfo.bundleNftId;
|
256
|
+
bundleInfo = instanceReader.getBundleInfo(bundleNftId);
|
257
|
+
require(bundleInfo.poolNftId == poolNftId, "POLICY_BUNDLE_MISMATCH");
|
258
|
+
|
259
|
+
// calculate required collateral
|
260
|
+
ISetup.PoolSetupInfo memory poolInfo = instanceReader.getPoolSetupInfo(poolNftId);
|
261
|
+
|
262
|
+
// obtain remaining return values
|
263
|
+
// TODO required collateral amount should be calculated by pool service, not policy service
|
264
|
+
collateralAmount = calculateRequiredCollateral(poolInfo.collateralizationLevel, policyInfo.sumInsuredAmount);
|
265
|
+
}
|
266
|
+
|
267
|
+
|
268
|
+
function decline(
|
269
|
+
NftId policyNftId
|
270
|
+
)
|
271
|
+
external
|
272
|
+
override
|
273
|
+
{
|
274
|
+
require(false, "ERROR:PRS-235:NOT_YET_IMPLEMENTED");
|
275
|
+
}
|
276
|
+
|
277
|
+
|
278
|
+
/// @dev underwites application which includes the locking of the required collateral from the pool.
|
279
|
+
function underwrite(
|
280
|
+
NftId applicationNftId, // = policyNftId
|
281
|
+
bool requirePremiumPayment,
|
282
|
+
Timestamp activateAt
|
283
|
+
)
|
284
|
+
external
|
285
|
+
virtual override
|
286
|
+
{
|
287
|
+
// check caller is registered product
|
288
|
+
IInstance instance;
|
289
|
+
InstanceReader instanceReader;
|
290
|
+
NftId productNftId;
|
291
|
+
{
|
292
|
+
IRegistry.ObjectInfo memory productInfo;
|
293
|
+
(productInfo, instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
294
|
+
instanceReader = instance.getInstanceReader();
|
295
|
+
productNftId = productInfo.nftId;
|
296
|
+
}
|
297
|
+
|
298
|
+
// check policy matches with calling product
|
299
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(applicationNftId);
|
300
|
+
require(policyInfo.productNftId == productNftId, "POLICY_PRODUCT_MISMATCH");
|
301
|
+
|
302
|
+
// check policy is in state applied
|
303
|
+
require(instanceReader.getPolicyState(applicationNftId) == APPLIED(), "ERROR:PRS-021:STATE_NOT_APPLIED");
|
304
|
+
|
305
|
+
(
|
306
|
+
NftId poolNftId,
|
307
|
+
NftId bundleNftId,
|
308
|
+
IBundle.BundleInfo memory bundleInfo,
|
309
|
+
uint256 collateralAmount
|
310
|
+
) = _getAndVerifyUnderwritingSetup(
|
311
|
+
instance,
|
312
|
+
instanceReader,
|
313
|
+
policyInfo,
|
314
|
+
instanceReader.getProductSetupInfo(productNftId)
|
315
|
+
);
|
316
|
+
|
317
|
+
StateId newPolicyState = UNDERWRITTEN();
|
318
|
+
|
319
|
+
// optional activation of policy
|
320
|
+
if(activateAt > zeroTimestamp()) {
|
321
|
+
newPolicyState = ACTIVE();
|
322
|
+
policyInfo.activatedAt = activateAt;
|
323
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
324
|
+
}
|
325
|
+
|
326
|
+
// lock bundle collateral
|
327
|
+
uint256 netPremiumAmount = 0; // > 0 if immediate premium payment
|
328
|
+
|
329
|
+
// optional collection of premium
|
330
|
+
if(requirePremiumPayment) {
|
331
|
+
netPremiumAmount = _processPremiumByTreasury(
|
332
|
+
instance,
|
333
|
+
productNftId,
|
334
|
+
applicationNftId,
|
335
|
+
policyInfo.premiumAmount);
|
336
|
+
|
337
|
+
policyInfo.premiumPaidAmount += policyInfo.premiumAmount;
|
338
|
+
}
|
339
|
+
|
340
|
+
// lock collateral and update bundle book keeping
|
341
|
+
// TODO introduct indirection via pool service?
|
342
|
+
// well pool would only need to be involved when a part of the collateral
|
343
|
+
// is provided by a "re insurance policy" of the pool
|
344
|
+
// but then again the policiy would likely best be attached to the bundle. really? why?
|
345
|
+
// retention level: fraction of sum insured that product will cover from pool funds directly
|
346
|
+
// eg retention level 30%, payouts up to 30% of the sum insured will be made from the product's pool directly
|
347
|
+
// for the remaining 70% the pool owns a policy that will cover claims that exceed the 30% of the sum insured
|
348
|
+
// open points:
|
349
|
+
// - do we need a link of a bundle to this policy or is it enough to know that the pool has an active policy?
|
350
|
+
// - when to buy such policies and for which amount? manual trigger or link to bundle creation and/or funding?
|
351
|
+
bundleInfo = _bundleService.lockCollateral(
|
352
|
+
instance,
|
353
|
+
applicationNftId,
|
354
|
+
bundleNftId,
|
355
|
+
collateralAmount,
|
356
|
+
netPremiumAmount);
|
357
|
+
|
358
|
+
instance.updatePolicy(applicationNftId, policyInfo, newPolicyState);
|
359
|
+
|
360
|
+
// also verify/confirm application by pool if necessary
|
361
|
+
if(instanceReader.getPoolSetupInfo(poolNftId).isVerifyingApplications) {
|
362
|
+
IPoolComponent pool = IPoolComponent(
|
363
|
+
getRegistry().getObjectInfo(poolNftId).objectAddress);
|
364
|
+
|
365
|
+
pool.verifyApplication(
|
366
|
+
applicationNftId,
|
367
|
+
policyInfo.applicationData,
|
368
|
+
bundleInfo.filter,
|
369
|
+
collateralAmount);
|
370
|
+
}
|
371
|
+
|
372
|
+
// TODO: add logging
|
373
|
+
}
|
374
|
+
|
375
|
+
|
376
|
+
function calculateRequiredCollateral(UFixed collateralizationLevel, uint256 sumInsuredAmount) public pure override returns(uint256 collateralAmount) {
|
377
|
+
UFixed sumInsuredUFixed = UFixedLib.toUFixed(sumInsuredAmount);
|
378
|
+
UFixed collateralUFixed = collateralizationLevel * sumInsuredUFixed;
|
379
|
+
return collateralUFixed.toInt();
|
380
|
+
}
|
381
|
+
|
382
|
+
function collectPremium(NftId policyNftId, Timestamp activateAt) external override {
|
383
|
+
// check caller is registered product
|
384
|
+
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
385
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
386
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
387
|
+
|
388
|
+
if (policyInfo.premiumPaidAmount == policyInfo.premiumAmount) {
|
389
|
+
revert ErrorIPolicyServicePremiumAlreadyPaid(policyNftId, policyInfo.premiumPaidAmount);
|
390
|
+
}
|
391
|
+
|
392
|
+
uint256 unpaidPremiumAmount = policyInfo.premiumAmount - policyInfo.premiumPaidAmount;
|
393
|
+
|
394
|
+
uint256 netPremiumAmount = _processPremiumByTreasury(
|
395
|
+
instance,
|
396
|
+
productInfo.nftId,
|
397
|
+
policyNftId,
|
398
|
+
unpaidPremiumAmount);
|
399
|
+
|
400
|
+
policyInfo.premiumPaidAmount += unpaidPremiumAmount;
|
401
|
+
|
402
|
+
_bundleService.increaseBalance(instance, policyInfo.bundleNftId, netPremiumAmount);
|
403
|
+
instance.updatePolicy(policyNftId, policyInfo, KEEP_STATE());
|
404
|
+
|
405
|
+
if(activateAt.gtz() && policyInfo.activatedAt.eqz()) {
|
406
|
+
activate(policyNftId, activateAt);
|
407
|
+
}
|
408
|
+
|
409
|
+
// TODO: add logging
|
410
|
+
}
|
411
|
+
|
412
|
+
function activate(NftId policyNftId, Timestamp activateAt) public override {
|
413
|
+
// check caller is registered product
|
414
|
+
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
415
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
416
|
+
|
417
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
418
|
+
|
419
|
+
require(
|
420
|
+
policyInfo.activatedAt.eqz(),
|
421
|
+
"ERROR:PRS-020:ALREADY_ACTIVATED");
|
422
|
+
|
423
|
+
policyInfo.activatedAt = activateAt;
|
424
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
425
|
+
|
426
|
+
instance.updatePolicy(policyNftId, policyInfo, ACTIVE());
|
427
|
+
|
428
|
+
// TODO: add logging
|
429
|
+
}
|
430
|
+
|
431
|
+
function close(
|
432
|
+
NftId policyNftId
|
433
|
+
) external override // solhint-disable-next-line no-empty-blocks
|
434
|
+
{
|
435
|
+
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
436
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
437
|
+
|
438
|
+
IPolicy.PolicyInfo memory policyInfo = instanceReader.getPolicyInfo(policyNftId);
|
439
|
+
|
440
|
+
if (policyInfo.activatedAt.eqz()) {
|
441
|
+
revert ErrorIPolicyServicePolicyNotActivated(policyNftId);
|
442
|
+
}
|
443
|
+
|
444
|
+
StateId state = instanceReader.getPolicyState(policyNftId);
|
445
|
+
if (state != ACTIVE()) {
|
446
|
+
revert ErrorIPolicyServicePolicyNotActive(policyNftId, state);
|
447
|
+
}
|
448
|
+
|
449
|
+
if (policyInfo.closedAt.gtz()) {
|
450
|
+
revert ErrorIPolicyServicePolicyAlreadyClosed(policyNftId);
|
451
|
+
}
|
452
|
+
|
453
|
+
if (policyInfo.premiumAmount != policyInfo.premiumPaidAmount) {
|
454
|
+
revert ErrorIPolicyServicePremiumNotFullyPaid(policyNftId, policyInfo.premiumAmount, policyInfo.premiumPaidAmount);
|
455
|
+
}
|
456
|
+
|
457
|
+
if (policyInfo.openClaimsCount > 0) {
|
458
|
+
revert ErrorIPolicyServiceOpenClaims(policyNftId, policyInfo.openClaimsCount);
|
459
|
+
}
|
460
|
+
|
461
|
+
if (TimestampLib.blockTimestamp().lte(policyInfo.expiredAt) && (policyInfo.payoutAmount < policyInfo.sumInsuredAmount)) {
|
462
|
+
revert ErrorIPolicyServicePolicyHasNotExpired(policyNftId, policyInfo.expiredAt);
|
463
|
+
}
|
464
|
+
|
465
|
+
policyInfo.closedAt = TimestampLib.blockTimestamp();
|
466
|
+
|
467
|
+
_bundleService.closePolicy(instance, policyNftId, policyInfo.bundleNftId, policyInfo.sumInsuredAmount);
|
468
|
+
instance.updatePolicy(policyNftId, policyInfo, CLOSED());
|
469
|
+
}
|
470
|
+
|
471
|
+
function _getPoolNftId(
|
472
|
+
IInstance instance,
|
473
|
+
NftId productNftId
|
474
|
+
)
|
475
|
+
internal
|
476
|
+
view
|
477
|
+
returns (NftId poolNftid)
|
478
|
+
{
|
479
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
480
|
+
ISetup.ProductSetupInfo memory productSetupInfo = instanceReader.getProductSetupInfo(productNftId);
|
481
|
+
return productSetupInfo.poolNftId;
|
482
|
+
}
|
483
|
+
|
484
|
+
|
485
|
+
function _processPremiumByTreasury(
|
486
|
+
IInstance instance,
|
487
|
+
NftId productNftId,
|
488
|
+
NftId policyNftId,
|
489
|
+
uint256 premiumAmount
|
490
|
+
)
|
491
|
+
internal
|
492
|
+
returns (uint256 netPremiumAmount)
|
493
|
+
{
|
494
|
+
// process token transfer(s)
|
495
|
+
if(premiumAmount > 0) {
|
496
|
+
ISetup.ProductSetupInfo memory productSetupInfo = instance.getInstanceReader().getProductSetupInfo(productNftId);
|
497
|
+
TokenHandler tokenHandler = productSetupInfo.tokenHandler;
|
498
|
+
address policyOwner = getRegistry().ownerOf(policyNftId);
|
499
|
+
ISetup.PoolSetupInfo memory poolSetupInfo = instance.getInstanceReader().getPoolSetupInfo(productSetupInfo.poolNftId);
|
500
|
+
address poolWallet = poolSetupInfo.wallet;
|
501
|
+
netPremiumAmount = premiumAmount;
|
502
|
+
Fee memory productFee = productSetupInfo.productFee;
|
503
|
+
|
504
|
+
if (FeeLib.feeIsZero(productFee)) {
|
505
|
+
tokenHandler.transfer(
|
506
|
+
policyOwner,
|
507
|
+
poolWallet,
|
508
|
+
premiumAmount
|
509
|
+
);
|
510
|
+
} else {
|
511
|
+
(uint256 productFeeAmount, uint256 netAmount) = FeeLib.calculateFee(productSetupInfo.productFee, netPremiumAmount);
|
512
|
+
address productWallet = productSetupInfo.wallet;
|
513
|
+
if (tokenHandler.getToken().allowance(policyOwner, address(tokenHandler)) < premiumAmount) {
|
514
|
+
revert ErrorIPolicyServiceInsufficientAllowance(policyOwner, address(tokenHandler), premiumAmount);
|
515
|
+
}
|
516
|
+
tokenHandler.transfer(policyOwner, productWallet, productFeeAmount);
|
517
|
+
tokenHandler.transfer(policyOwner, poolWallet, netAmount);
|
518
|
+
netPremiumAmount = netAmount;
|
519
|
+
}
|
520
|
+
}
|
521
|
+
|
522
|
+
// TODO: add logging
|
523
|
+
}
|
524
|
+
}
|
@@ -0,0 +1,54 @@
|
|
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 {PolicyService} from "./PolicyService.sol";
|
7
|
+
import {Registry} from "../../registry/Registry.sol";
|
8
|
+
import {RegistryService} from "../../registry/RegistryService.sol";
|
9
|
+
import {VersionLib} from "../../types/Version.sol";
|
10
|
+
|
11
|
+
contract PolicyServiceManager is ProxyManager {
|
12
|
+
|
13
|
+
PolicyService private _policyService;
|
14
|
+
|
15
|
+
/// @dev initializes proxy manager with product service implementation
|
16
|
+
constructor(
|
17
|
+
address registryAddress
|
18
|
+
)
|
19
|
+
ProxyManager()
|
20
|
+
{
|
21
|
+
PolicyService svc = new PolicyService();
|
22
|
+
bytes memory data = abi.encode(registryAddress, address(this));
|
23
|
+
IVersionable versionable = deploy(
|
24
|
+
address(svc),
|
25
|
+
data);
|
26
|
+
|
27
|
+
_policyService = PolicyService(address(versionable));
|
28
|
+
|
29
|
+
// Registry registry = Registry(registryAddress);
|
30
|
+
// address registryServiceAddress = registry.getServiceAddress("RegistryService", VersionLib.toVersion(3, 0, 0).toMajorPart());
|
31
|
+
// RegistryService registryService = RegistryService(registryServiceAddress);
|
32
|
+
// TODO this must have a role or own nft to register service
|
33
|
+
//registryService.registerService(_productService);
|
34
|
+
|
35
|
+
// TODO no nft to link yet
|
36
|
+
// link ownership of instance service manager ot nft owner of instance service
|
37
|
+
//_linkToNftOwnable(
|
38
|
+
// address(registryAddress),
|
39
|
+
// address(_productService));
|
40
|
+
|
41
|
+
// implies that after this constructor call only upgrade functionality is available
|
42
|
+
_isDeployed = true;
|
43
|
+
}
|
44
|
+
|
45
|
+
//--- view functions ----------------------------------------------------//
|
46
|
+
function getPolicyService()
|
47
|
+
external
|
48
|
+
view
|
49
|
+
returns (PolicyService policyService)
|
50
|
+
{
|
51
|
+
return _policyService;
|
52
|
+
}
|
53
|
+
|
54
|
+
}
|