@etherisc/gif-next 0.0.2-f99f1d2-109 → 0.0.2-fc8b370-882
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 +90 -7
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{Component.sol/Component.json → BaseComponent.sol/BaseComponent.json} +26 -57
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +4 -0
- package/artifacts/contracts/{instance/component/IComponent.sol/IComponentContract.json → components/IBaseComponent.sol/IBaseComponent.json} +26 -57
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +356 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/components/{IPool.sol/IPoolComponent.json → IProductComponent.sol/IProductComponent.json} +89 -65
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +134 -75
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +72 -113
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +2 -2
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +1 -1
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +2 -2
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +1 -1
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +2 -2
- 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/TypeA.sol/TypeALib.json +2 -2
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +1 -1
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +719 -332
- package/artifacts/contracts/instance/IInstanceLinked.sol/IInstanceLinked.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol → IInstanceLinked.sol}/IInstanceLinked.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +998 -527
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/ComponentModule.sol/ComponentModule.json → base/ComponentServiceBase.sol/ComponentServiceBase.json} +133 -132
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/{product/ProductService.sol/ProductModule.json → base/IInstanceBase.sol/IInstanceBase.json} +18 -30
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +511 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/{lifecycle/ILifecycle.sol/ILifecycleModule.json → base/ILifecycle.sol/ILifecycle.json} +10 -77
- package/artifacts/contracts/instance/base/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IService.sol/IService.json +300 -0
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/InstanceBase.sol/InstanceBase.json +326 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +692 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +169 -0
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ModuleBase.sol/ModuleBase.json +10 -0
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ServiceBase.sol/ServiceBase.json +300 -0
- package/artifacts/contracts/instance/module/access/Access.sol/AccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/Access.sol/AccessModule.json +85 -152
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/IAccess.sol/IAccess.json +1 -1
- package/artifacts/contracts/instance/module/access/IAccess.sol/IAccessModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{access → module/access}/IAccess.sol/IAccessModule.json +96 -99
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/BundleModule.sol/BundleModule.json +296 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundle.json +10 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/bundle/IBundle.sol/IBundleModule.json +296 -0
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/CompensationModule.sol/CompensationModule.json +10 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensation.json +10 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/compensation/ICompensation.sol/ICompensationModule.json +10 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/component/ComponentModule.sol/ComponentModule.json +188 -0
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/instance/{component → module/component}/IComponent.sol/IComponent.json +1 -1
- package/artifacts/contracts/instance/module/component/IComponent.sol/IComponentModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{component → module/component}/IComponent.sol/IComponentModule.json +33 -62
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/IPolicy.sol/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/policy/IPolicy.sol/IPolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/IPolicy.sol/IPolicyModule.json +132 -125
- package/artifacts/contracts/instance/module/policy/PolicyModule.sol/PolicyModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module/policy}/PolicyModule.sol/PolicyModule.json +132 -125
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPool.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool → module/pool}/IPoolModule.sol/IPool.json +1 -1
- package/artifacts/contracts/instance/module/pool/IPoolModule.sol/IPoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool → module/pool}/IPoolModule.sol/IPoolModule.json +67 -47
- package/artifacts/contracts/instance/module/pool/PoolModule.sol/PoolModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool → module/pool}/PoolModule.sol/PoolModule.json +51 -57
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRisk.json +10 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/IRisk.sol/IRiskModule.json +10 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.dbg.json +4 -0
- package/artifacts/contracts/instance/module/risk/RiskModule.sol/RiskModule.json +10 -0
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/{treasury → module/treasury}/ITreasury.sol/ITreasury.json +1 -1
- package/artifacts/contracts/instance/module/treasury/ITreasury.sol/ITreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{treasury → module/treasury}/ITreasury.sol/ITreasuryModule.json +100 -57
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/instance/module/treasury/TokenHandler.sol/TokenHandler.json +76 -0
- package/artifacts/contracts/instance/module/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +4 -0
- package/artifacts/contracts/instance/{treasury → module/treasury}/TreasuryModule.sol/TreasuryModule.json +100 -57
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +523 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +364 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +376 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +477 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +471 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +673 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +65 -2
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +147 -30
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryLinked.sol/IRegistryLinked.json +24 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +241 -25
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +35 -0
- package/artifacts/contracts/shared/IOwnable.sol/IOwnable.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IOwnable.sol}/IOwnable.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IRegisterable.sol}/IRegisterable.json +16 -61
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +164 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/{registry/Registry.sol → shared/Registerable.sol}/Registerable.json +16 -61
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +164 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +4 -0
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +119 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.dbg.json +4 -0
- package/artifacts/contracts/test/TestPool.sol/TestPool.json +387 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.dbg.json +4 -0
- package/artifacts/contracts/test/TestProduct.sol/TestProduct.json +393 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +4 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +137 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +4 -0
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +116 -0
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +4 -0
- package/artifacts/contracts/test/TestService.sol/TestService.json +379 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +4 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +338 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +218 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +4 -0
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +206 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +4 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.json +338 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.json +10 -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/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +218 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +111 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +65 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +10 -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/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +30 -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 +64 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +88 -62
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.json +139 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +30 -0
- package/contracts/components/BaseComponent.sol +88 -0
- package/contracts/components/IBaseComponent.sol +19 -0
- package/contracts/components/IPoolComponent.sol +57 -0
- package/contracts/components/{IProduct.sol → IProductComponent.sol} +9 -6
- package/contracts/components/Pool.sol +140 -18
- package/contracts/components/Product.sol +53 -25
- package/contracts/instance/IInstance.sol +38 -11
- package/contracts/instance/IInstanceLinked.sol +8 -0
- package/contracts/instance/Instance.sol +44 -48
- package/contracts/instance/base/ComponentServiceBase.sol +42 -0
- package/contracts/instance/base/IInstanceBase.sol +14 -0
- package/contracts/instance/base/IKeyValueStore.sol +49 -0
- package/contracts/instance/{lifecycle → base}/ILifecycle.sol +4 -21
- package/contracts/instance/base/IService.sol +15 -0
- package/contracts/instance/base/InstanceBase.sol +80 -0
- package/contracts/instance/base/KeyValueStore.sol +156 -0
- package/contracts/instance/{lifecycle/LifecycleModule.sol → base/Lifecycle.sol} +36 -29
- package/contracts/instance/base/ModuleBase.sol +52 -0
- package/contracts/instance/base/ServiceBase.sol +37 -0
- package/contracts/instance/module/access/Access.sol +149 -0
- package/contracts/instance/module/access/IAccess.sol +53 -0
- package/contracts/instance/module/bundle/BundleModule.sol +136 -0
- package/contracts/instance/module/bundle/IBundle.sol +58 -0
- package/contracts/instance/module/compensation/CompensationModule.sol +8 -0
- package/contracts/instance/module/compensation/ICompensation.sol +10 -0
- package/contracts/instance/module/component/ComponentModule.sol +95 -0
- package/contracts/instance/module/component/IComponent.sol +53 -0
- package/contracts/instance/module/policy/IPolicy.sol +60 -0
- package/contracts/instance/module/policy/PolicyModule.sol +76 -0
- package/contracts/instance/module/pool/IPoolModule.sol +41 -0
- package/contracts/instance/module/pool/PoolModule.sol +87 -0
- package/contracts/instance/module/risk/IRisk.sol +10 -0
- package/contracts/instance/module/risk/RiskModule.sol +8 -0
- package/contracts/instance/{treasury → module/treasury}/ITreasury.sol +27 -15
- package/contracts/instance/module/treasury/TokenHandler.sol +48 -0
- package/contracts/instance/{treasury → module/treasury}/TreasuryModule.sol +43 -59
- package/contracts/instance/service/ComponentOwnerService.sol +170 -0
- package/contracts/instance/service/IComponentOwnerService.sol +22 -0
- package/contracts/instance/service/IPoolService.sol +30 -0
- package/contracts/instance/service/IProductService.sol +58 -0
- package/contracts/instance/service/PoolService.sol +123 -0
- package/contracts/instance/service/ProductService.sol +354 -0
- package/contracts/registry/ChainNft.sol +61 -37
- package/contracts/registry/IRegistry.sol +24 -34
- package/contracts/registry/IRegistryLinked.sol +8 -0
- package/contracts/registry/Registry.sol +284 -85
- package/contracts/shared/ERC165.sol +21 -0
- package/contracts/shared/IOwnable.sol +6 -0
- package/contracts/shared/IRegisterable.sol +24 -0
- package/contracts/shared/IVersionable.sol +52 -0
- package/contracts/shared/Registerable.sol +86 -0
- package/contracts/shared/Versionable.sol +89 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestPool.sol +22 -0
- package/contracts/test/TestProduct.sol +44 -0
- package/contracts/test/TestRegisterable.sol +19 -0
- package/contracts/test/TestRoleId.sol +14 -0
- package/contracts/test/TestService.sol +32 -0
- package/contracts/test/TestToken.sol +26 -0
- package/contracts/test/TestVersion.sol +44 -0
- package/contracts/test/TestVersionable.sol +17 -0
- package/contracts/test/Usdc.sol +26 -0
- package/contracts/types/AddressSet.sol +58 -0
- package/contracts/types/Fee.sol +39 -20
- package/contracts/types/Key32.sol +45 -0
- package/contracts/types/NftId.sol +22 -1
- package/contracts/types/NftIdSet.sol +60 -0
- package/contracts/types/ObjectType.sol +22 -14
- package/contracts/types/RoleId.sol +38 -0
- package/contracts/types/StateId.sol +13 -3
- package/contracts/types/Timestamp.sol +22 -1
- package/contracts/types/UFixed.sol +26 -23
- package/contracts/types/Version.sol +95 -0
- package/package.json +9 -3
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +0 -35
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +0 -74
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.json +0 -35
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.json +0 -50
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +0 -202
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +0 -141
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycle.json +0 -134
- package/artifacts/contracts/instance/lifecycle/ILifecycle.sol/ILifecycleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/lifecycle/LifecycleModule.sol/LifecycleModule.dbg.json +0 -4
- package/artifacts/contracts/instance/lifecycle/LifecycleModule.sol/LifecycleModule.json +0 -221
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.json +0 -75
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.json +0 -127
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -196
- package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/treasury/ITreasury.sol/ITreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/instance/treasury/TokenHandler.sol/TokenHandler.dbg.json +0 -4
- package/artifacts/contracts/instance/treasury/TokenHandler.sol/TokenHandler.json +0 -45
- package/artifacts/contracts/instance/treasury/TreasuryModule.sol/TreasuryModule.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.json +0 -49
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +0 -60
- package/contracts/components/Component.sol +0 -77
- package/contracts/components/IPool.sol +0 -15
- package/contracts/instance/access/Access.sol +0 -165
- package/contracts/instance/access/IAccess.sol +0 -63
- package/contracts/instance/component/ComponentModule.sol +0 -274
- package/contracts/instance/component/IComponent.sol +0 -74
- package/contracts/instance/policy/IPolicy.sol +0 -50
- package/contracts/instance/policy/PolicyModule.sol +0 -114
- package/contracts/instance/pool/IPoolModule.sol +0 -23
- package/contracts/instance/pool/PoolModule.sol +0 -81
- package/contracts/instance/product/IProductService.sol +0 -36
- package/contracts/instance/product/ProductService.sol +0 -136
- package/contracts/instance/treasury/TokenHandler.sol +0 -24
@@ -0,0 +1,22 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {NftId} from "../../types/NftId.sol";
|
5
|
+
import {ObjectType} from "../../types/ObjectType.sol";
|
6
|
+
import {RoleId} from "../../types/RoleId.sol";
|
7
|
+
import {IBaseComponent} from "../../components/IBaseComponent.sol";
|
8
|
+
import {IService} from "../base/IService.sol";
|
9
|
+
|
10
|
+
// TODO rename to registry service
|
11
|
+
interface IComponentOwnerService is IService {
|
12
|
+
|
13
|
+
function register(IBaseComponent component) external returns(NftId componentNftId);
|
14
|
+
|
15
|
+
// TODO move to product/pool services
|
16
|
+
function lock(IBaseComponent component) external;
|
17
|
+
|
18
|
+
// TODO move to product/pool services
|
19
|
+
function unlock(IBaseComponent component) external;
|
20
|
+
|
21
|
+
function getRoleForType(ObjectType cType) external pure returns (RoleId role);
|
22
|
+
}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {NftId} from "../../types/NftId.sol";
|
5
|
+
import {Fee} from "../../types/Fee.sol";
|
6
|
+
import {IService} from "../base/IService.sol";
|
7
|
+
|
8
|
+
interface IPoolService is IService {
|
9
|
+
function setFees(
|
10
|
+
Fee memory stakingFee,
|
11
|
+
Fee memory performanceFee
|
12
|
+
) external;
|
13
|
+
|
14
|
+
function createBundle(
|
15
|
+
address owner,
|
16
|
+
uint256 amount,
|
17
|
+
uint256 lifetime,
|
18
|
+
bytes calldata filter
|
19
|
+
) external returns(NftId bundleNftId);
|
20
|
+
|
21
|
+
// function fundBundle(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
22
|
+
|
23
|
+
// function defundBundle(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
24
|
+
|
25
|
+
// function lockBundle(NftId bundleNftId) external;
|
26
|
+
|
27
|
+
// function unlockBundle(NftId bundleNftId) external;
|
28
|
+
|
29
|
+
// function closeBundle(NftId bundleNftId) external;
|
30
|
+
}
|
@@ -0,0 +1,58 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {NftId} from "../../types/NftId.sol";
|
5
|
+
import {Timestamp} from "../../types/Timestamp.sol";
|
6
|
+
import {UFixed} from "../../types/UFixed.sol";
|
7
|
+
import {Fee} from "../../types/Fee.sol";
|
8
|
+
import {IService} from "../base/IService.sol";
|
9
|
+
|
10
|
+
interface IProductService is IService {
|
11
|
+
function setFees(
|
12
|
+
Fee memory policyFee,
|
13
|
+
Fee memory processingFee
|
14
|
+
) external;
|
15
|
+
|
16
|
+
function createApplication(
|
17
|
+
address applicationOwner,
|
18
|
+
uint256 sumInsuredAmount,
|
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
|
36
|
+
) external;
|
37
|
+
|
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
|
+
|
45
|
+
|
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
|
+
|
58
|
+
}
|
@@ -0,0 +1,123 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
+
import {IInstance} from "../../instance/IInstance.sol";
|
6
|
+
import {ITreasury, ITreasuryModule, TokenHandler} from "../../instance/module/treasury/ITreasury.sol";
|
7
|
+
|
8
|
+
import {IVersionable} from "../../shared/IVersionable.sol";
|
9
|
+
import {Versionable} from "../../shared/Versionable.sol";
|
10
|
+
|
11
|
+
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
12
|
+
import {POOL, BUNDLE} from "../../types/ObjectType.sol";
|
13
|
+
import {Fee} from "../../types/Fee.sol";
|
14
|
+
import {Version, VersionLib} from "../../types/Version.sol";
|
15
|
+
|
16
|
+
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
17
|
+
import {IPoolService} from "./IPoolService.sol";
|
18
|
+
|
19
|
+
|
20
|
+
contract PoolService is ComponentServiceBase, IPoolService {
|
21
|
+
using NftIdLib for NftId;
|
22
|
+
|
23
|
+
string public constant NAME = "PoolService";
|
24
|
+
|
25
|
+
constructor(
|
26
|
+
address registry,
|
27
|
+
NftId registryNftId
|
28
|
+
) ComponentServiceBase(registry, registryNftId) // solhint-disable-next-line no-empty-blocks
|
29
|
+
{
|
30
|
+
_registerInterface(type(IPoolService).interfaceId);
|
31
|
+
}
|
32
|
+
|
33
|
+
function getVersion()
|
34
|
+
public
|
35
|
+
pure
|
36
|
+
virtual override (IVersionable, Versionable)
|
37
|
+
returns(Version)
|
38
|
+
{
|
39
|
+
return VersionLib.toVersion(3,0,0);
|
40
|
+
}
|
41
|
+
|
42
|
+
function getName() external pure override returns(string memory name) {
|
43
|
+
return NAME;
|
44
|
+
}
|
45
|
+
|
46
|
+
function setFees(
|
47
|
+
Fee memory stakingFee,
|
48
|
+
Fee memory performanceFee
|
49
|
+
)
|
50
|
+
external
|
51
|
+
override
|
52
|
+
{
|
53
|
+
(IRegistry.ObjectInfo memory info, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
54
|
+
instance.setPoolFees(info.nftId, stakingFee, performanceFee);
|
55
|
+
}
|
56
|
+
|
57
|
+
function createBundle(
|
58
|
+
address owner,
|
59
|
+
uint256 stakingAmount,
|
60
|
+
uint256 lifetime,
|
61
|
+
bytes calldata filter
|
62
|
+
)
|
63
|
+
external
|
64
|
+
override
|
65
|
+
returns(NftId bundleNftId)
|
66
|
+
{
|
67
|
+
(IRegistry.ObjectInfo memory info, IInstance instance) = _getAndVerifyComponentInfoAndInstance(POOL());
|
68
|
+
|
69
|
+
// register bundle with registry
|
70
|
+
NftId poolNftId = info.nftId;
|
71
|
+
bundleNftId = _registry.registerObjectForInstance(
|
72
|
+
poolNftId,
|
73
|
+
BUNDLE(),
|
74
|
+
owner,
|
75
|
+
"");
|
76
|
+
|
77
|
+
// create bundle info in instance
|
78
|
+
instance.createBundleInfo(
|
79
|
+
bundleNftId,
|
80
|
+
poolNftId,
|
81
|
+
stakingAmount,
|
82
|
+
lifetime,
|
83
|
+
filter);
|
84
|
+
|
85
|
+
// add bundle to pool in instance
|
86
|
+
instance.addBundleToPool(
|
87
|
+
bundleNftId,
|
88
|
+
poolNftId,
|
89
|
+
stakingAmount);
|
90
|
+
|
91
|
+
// collect capital
|
92
|
+
_processStakingByTreasury(
|
93
|
+
instance,
|
94
|
+
poolNftId,
|
95
|
+
bundleNftId,
|
96
|
+
stakingAmount);
|
97
|
+
|
98
|
+
// TODO add logging
|
99
|
+
}
|
100
|
+
|
101
|
+
|
102
|
+
function _processStakingByTreasury(
|
103
|
+
IInstance instance,
|
104
|
+
NftId poolNftId,
|
105
|
+
NftId bundleNftId,
|
106
|
+
uint256 stakingAmount
|
107
|
+
)
|
108
|
+
internal
|
109
|
+
{
|
110
|
+
// process token transfer(s)
|
111
|
+
if(stakingAmount > 0) {
|
112
|
+
TokenHandler tokenHandler = instance.getTokenHandler(poolNftId);
|
113
|
+
address bundleOwner = _registry.getOwner(bundleNftId);
|
114
|
+
address poolWallet = instance.getPoolSetup(poolNftId).wallet;
|
115
|
+
|
116
|
+
tokenHandler.transfer(
|
117
|
+
bundleOwner,
|
118
|
+
poolWallet,
|
119
|
+
stakingAmount
|
120
|
+
);
|
121
|
+
}
|
122
|
+
}
|
123
|
+
}
|
@@ -0,0 +1,354 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.19;
|
3
|
+
|
4
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
|
+
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
6
|
+
import {IInstance} from "../../instance/IInstance.sol";
|
7
|
+
import {IPolicy, IPolicyModule} from "../module/policy/IPolicy.sol";
|
8
|
+
import {IPool} from "../module/pool/IPoolModule.sol";
|
9
|
+
import {IBundle} from "../module/bundle/IBundle.sol";
|
10
|
+
import {IProductService} from "./IProductService.sol";
|
11
|
+
import {ITreasury, ITreasuryModule, TokenHandler} from "../../instance/module/treasury/ITreasury.sol";
|
12
|
+
|
13
|
+
import {IVersionable} from "../../shared/IVersionable.sol";
|
14
|
+
import {Versionable} from "../../shared/Versionable.sol";
|
15
|
+
|
16
|
+
import {Timestamp, zeroTimestamp} from "../../types/Timestamp.sol";
|
17
|
+
import {UFixed, UFixedMathLib} from "../../types/UFixed.sol";
|
18
|
+
import {ObjectType, INSTANCE, PRODUCT, POLICY} from "../../types/ObjectType.sol";
|
19
|
+
import {APPLIED, UNDERWRITTEN, ACTIVE} from "../../types/StateId.sol";
|
20
|
+
import {NftId, NftIdLib} from "../../types/NftId.sol";
|
21
|
+
import {Blocknumber, blockNumber} from "../../types/Blocknumber.sol";
|
22
|
+
import {Fee, FeeLib} from "../../types/Fee.sol";
|
23
|
+
import {Version, VersionLib} from "../../types/Version.sol";
|
24
|
+
|
25
|
+
import {ComponentServiceBase} from "../base/ComponentServiceBase.sol";
|
26
|
+
import {IProductService} from "./IProductService.sol";
|
27
|
+
|
28
|
+
// TODO or name this ProtectionService to have Product be something more generic (loan, savings account, ...)
|
29
|
+
contract ProductService is ComponentServiceBase, IProductService {
|
30
|
+
using NftIdLib for NftId;
|
31
|
+
|
32
|
+
string public constant NAME = "ProductService";
|
33
|
+
|
34
|
+
event LogProductServiceSender(address sender);
|
35
|
+
|
36
|
+
constructor(
|
37
|
+
address registry,
|
38
|
+
NftId registryNftId
|
39
|
+
) ComponentServiceBase(registry, registryNftId) // solhint-disable-next-line no-empty-blocks
|
40
|
+
{
|
41
|
+
_registerInterface(type(IProductService).interfaceId);
|
42
|
+
}
|
43
|
+
|
44
|
+
function getVersion()
|
45
|
+
public
|
46
|
+
pure
|
47
|
+
virtual override (IVersionable, Versionable)
|
48
|
+
returns(Version)
|
49
|
+
{
|
50
|
+
return VersionLib.toVersion(3,0,0);
|
51
|
+
}
|
52
|
+
|
53
|
+
function getName() external pure override returns(string memory name) {
|
54
|
+
return NAME;
|
55
|
+
}
|
56
|
+
|
57
|
+
function setFees(
|
58
|
+
Fee memory policyFee,
|
59
|
+
Fee memory processingFee
|
60
|
+
)
|
61
|
+
external
|
62
|
+
override
|
63
|
+
{
|
64
|
+
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
65
|
+
instance.setProductFees(productInfo.nftId, policyFee, processingFee);
|
66
|
+
}
|
67
|
+
|
68
|
+
function createApplication(
|
69
|
+
address applicationOwner,
|
70
|
+
uint256 sumInsuredAmount,
|
71
|
+
uint256 premiumAmount,
|
72
|
+
uint256 lifetime,
|
73
|
+
NftId bundleNftId
|
74
|
+
) external override returns (NftId policyNftId) {
|
75
|
+
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
76
|
+
NftId productNftId = productInfo.nftId;
|
77
|
+
// TODO add validations (see create bundle in pool service)
|
78
|
+
|
79
|
+
policyNftId = this.getRegistry().registerObjectForInstance(
|
80
|
+
productNftId,
|
81
|
+
POLICY(),
|
82
|
+
applicationOwner,
|
83
|
+
""
|
84
|
+
);
|
85
|
+
|
86
|
+
instance.createApplication(
|
87
|
+
productNftId,
|
88
|
+
policyNftId,
|
89
|
+
sumInsuredAmount,
|
90
|
+
premiumAmount,
|
91
|
+
lifetime,
|
92
|
+
bundleNftId
|
93
|
+
);
|
94
|
+
|
95
|
+
// TODO add logging
|
96
|
+
}
|
97
|
+
|
98
|
+
function _getAndVerifyUnderwritingSetup(
|
99
|
+
IInstance instance,
|
100
|
+
IPolicy.PolicyInfo memory policyInfo
|
101
|
+
)
|
102
|
+
internal
|
103
|
+
view
|
104
|
+
returns (
|
105
|
+
ITreasury.ProductSetup memory productSetup,
|
106
|
+
IBundle.BundleInfo memory bundleInfo,
|
107
|
+
uint256 collateralAmount,
|
108
|
+
bool poolIsVerifying,
|
109
|
+
bytes memory bundleFilter
|
110
|
+
)
|
111
|
+
{
|
112
|
+
// check match between policy and bundle (via pool)
|
113
|
+
productSetup = instance.getProductSetup(policyInfo.productNftId);
|
114
|
+
bundleInfo = instance.getBundleInfo(policyInfo.bundleNftId);
|
115
|
+
require(bundleInfo.poolNftId == productSetup.poolNftId, "POLICY_BUNDLE_MISMATCH");
|
116
|
+
|
117
|
+
// calculate required collateral
|
118
|
+
NftId poolNftId = productSetup.poolNftId;
|
119
|
+
IPool.PoolInfo memory poolInfo = instance.getPoolInfo(poolNftId);
|
120
|
+
|
121
|
+
// obtain remaining return values
|
122
|
+
poolIsVerifying = poolInfo.isVerifying;
|
123
|
+
collateralAmount = calculateRequiredCollateral(poolInfo.collateralizationLevel, policyInfo.sumInsuredAmount);
|
124
|
+
bundleFilter = bundleInfo.filter;
|
125
|
+
}
|
126
|
+
|
127
|
+
function _lockCollateralInBundle(
|
128
|
+
IInstance instance,
|
129
|
+
IBundle.BundleInfo memory bundleInfo,
|
130
|
+
NftId policyNftId,
|
131
|
+
uint256 collateralAmount
|
132
|
+
)
|
133
|
+
internal
|
134
|
+
returns (IBundle.BundleInfo memory)
|
135
|
+
{
|
136
|
+
bundleInfo.lockedAmount += collateralAmount;
|
137
|
+
instance.collateralizePolicy(bundleInfo.nftId, policyNftId, collateralAmount);
|
138
|
+
return bundleInfo;
|
139
|
+
}
|
140
|
+
|
141
|
+
function _underwriteByPool(
|
142
|
+
ITreasury.ProductSetup memory productSetup,
|
143
|
+
IPolicy.PolicyInfo memory policyInfo,
|
144
|
+
bytes memory bundleFilter,
|
145
|
+
uint256 collateralAmount
|
146
|
+
)
|
147
|
+
internal
|
148
|
+
{
|
149
|
+
address poolAddress = _registry.getObjectInfo(productSetup.poolNftId).objectAddress;
|
150
|
+
IPoolComponent pool = IPoolComponent(poolAddress);
|
151
|
+
pool.underwrite(
|
152
|
+
policyInfo.nftId,
|
153
|
+
policyInfo.data,
|
154
|
+
bundleFilter,
|
155
|
+
collateralAmount);
|
156
|
+
}
|
157
|
+
|
158
|
+
|
159
|
+
function underwrite(
|
160
|
+
NftId policyNftId,
|
161
|
+
bool requirePremiumPayment,
|
162
|
+
Timestamp activateAt
|
163
|
+
)
|
164
|
+
external
|
165
|
+
override
|
166
|
+
{
|
167
|
+
// check caller is registered product
|
168
|
+
(
|
169
|
+
IRegistry.ObjectInfo memory productInfo,
|
170
|
+
IInstance instance
|
171
|
+
) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
172
|
+
|
173
|
+
// check match between policy and calling product
|
174
|
+
NftId productNftId = productInfo.nftId;
|
175
|
+
IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
176
|
+
require(policyInfo.productNftId == productNftId, "POLICY_PRODUCT_MISMATCH");
|
177
|
+
require(policyInfo.state == APPLIED(), "ERROR:PRS-021:STATE_NOT_APPLIED");
|
178
|
+
|
179
|
+
(
|
180
|
+
ITreasury.ProductSetup memory productSetup,
|
181
|
+
IBundle.BundleInfo memory bundleInfo,
|
182
|
+
uint256 collateralAmount,
|
183
|
+
bool poolIsVerifying,
|
184
|
+
bytes memory bundleFilter
|
185
|
+
) = _getAndVerifyUnderwritingSetup(
|
186
|
+
instance,
|
187
|
+
policyInfo
|
188
|
+
);
|
189
|
+
|
190
|
+
// lock bundle collateral
|
191
|
+
bundleInfo = _lockCollateralInBundle(
|
192
|
+
instance,
|
193
|
+
bundleInfo,
|
194
|
+
policyNftId,
|
195
|
+
collateralAmount);
|
196
|
+
|
197
|
+
// collect premium
|
198
|
+
if(requirePremiumPayment) {
|
199
|
+
uint256 netPremiumAmount = _processPremiumByTreasury(
|
200
|
+
instance,
|
201
|
+
productSetup,
|
202
|
+
policyNftId,
|
203
|
+
policyInfo.premiumAmount);
|
204
|
+
|
205
|
+
policyInfo.premiumPaidAmount += policyInfo.premiumAmount;
|
206
|
+
bundleInfo.balanceAmount += netPremiumAmount;
|
207
|
+
}
|
208
|
+
|
209
|
+
// set policy state to underwritten
|
210
|
+
// TODO add require for state change
|
211
|
+
policyInfo.state = UNDERWRITTEN();
|
212
|
+
policyInfo.updatedIn = blockNumber();
|
213
|
+
|
214
|
+
// optional activation of policy
|
215
|
+
if(activateAt > zeroTimestamp()) {
|
216
|
+
policyInfo.activatedAt = activateAt;
|
217
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
218
|
+
|
219
|
+
// TODO add require for state change
|
220
|
+
policyInfo.state = ACTIVE();
|
221
|
+
}
|
222
|
+
|
223
|
+
instance.setPolicyInfo(policyInfo);
|
224
|
+
instance.setBundleInfo(bundleInfo);
|
225
|
+
|
226
|
+
// integrate pool component
|
227
|
+
if(poolIsVerifying) {
|
228
|
+
_underwriteByPool(
|
229
|
+
productSetup,
|
230
|
+
policyInfo,
|
231
|
+
bundleFilter,
|
232
|
+
collateralAmount
|
233
|
+
);
|
234
|
+
}
|
235
|
+
|
236
|
+
// TODO add logging
|
237
|
+
}
|
238
|
+
|
239
|
+
function calculateRequiredCollateral(UFixed collateralizationLevel, uint256 sumInsuredAmount) public pure override returns(uint256 collateralAmount) {
|
240
|
+
UFixed sumInsuredUFixed = UFixedMathLib.toUFixed(sumInsuredAmount);
|
241
|
+
UFixed collateralUFixed = collateralizationLevel * sumInsuredUFixed;
|
242
|
+
return collateralUFixed.toInt();
|
243
|
+
}
|
244
|
+
|
245
|
+
function collectPremium(NftId policyNftId, Timestamp activateAt) external override {
|
246
|
+
// check caller is registered product
|
247
|
+
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
248
|
+
|
249
|
+
// perform actual token transfers
|
250
|
+
IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
251
|
+
ITreasury.ProductSetup memory product = instance.getProductSetup(productInfo.nftId);
|
252
|
+
|
253
|
+
uint256 premiumAmount = policyInfo.premiumAmount;
|
254
|
+
_processPremiumByTreasury(instance, product, policyNftId, premiumAmount);
|
255
|
+
|
256
|
+
// policy level book keeping for premium paid
|
257
|
+
policyInfo.premiumPaidAmount += premiumAmount;
|
258
|
+
policyInfo.updatedIn = blockNumber();
|
259
|
+
|
260
|
+
// optional activation of policy
|
261
|
+
if(activateAt > zeroTimestamp()) {
|
262
|
+
require(
|
263
|
+
policyInfo.activatedAt.eqz(),
|
264
|
+
"ERROR:PRS-030:ALREADY_ACTIVATED");
|
265
|
+
|
266
|
+
policyInfo.activatedAt = activateAt;
|
267
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
268
|
+
|
269
|
+
// TODO add require for state change
|
270
|
+
policyInfo.state = ACTIVE();
|
271
|
+
}
|
272
|
+
|
273
|
+
instance.setPolicyInfo(policyInfo);
|
274
|
+
|
275
|
+
// TODO add logging
|
276
|
+
}
|
277
|
+
|
278
|
+
function activate(NftId policyNftId, Timestamp activateAt) external override {
|
279
|
+
// check caller is registered product
|
280
|
+
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
281
|
+
|
282
|
+
IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
283
|
+
|
284
|
+
require(
|
285
|
+
policyInfo.activatedAt.eqz(),
|
286
|
+
"ERROR:PRS-020:ALREADY_ACTIVATED");
|
287
|
+
|
288
|
+
policyInfo.activatedAt = activateAt;
|
289
|
+
policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
290
|
+
|
291
|
+
// TODO add require for state change
|
292
|
+
policyInfo.state = ACTIVE();
|
293
|
+
|
294
|
+
instance.setPolicyInfo(policyInfo);
|
295
|
+
|
296
|
+
// TODO add logging
|
297
|
+
}
|
298
|
+
|
299
|
+
function close(
|
300
|
+
NftId policyNftId
|
301
|
+
) external override // solhint-disable-next-line no-empty-blocks
|
302
|
+
{
|
303
|
+
|
304
|
+
}
|
305
|
+
|
306
|
+
function _getPoolNftId(
|
307
|
+
IInstance instance,
|
308
|
+
NftId productNftId
|
309
|
+
)
|
310
|
+
internal
|
311
|
+
view
|
312
|
+
returns (NftId poolNftid)
|
313
|
+
{
|
314
|
+
return instance.getProductSetup(productNftId).poolNftId;
|
315
|
+
}
|
316
|
+
|
317
|
+
function _processPremiumByTreasury(
|
318
|
+
IInstance instance,
|
319
|
+
ITreasury.ProductSetup memory product,
|
320
|
+
NftId policyNftId,
|
321
|
+
uint256 premiumAmount
|
322
|
+
)
|
323
|
+
internal
|
324
|
+
returns (uint256 netPremiumAmount)
|
325
|
+
{
|
326
|
+
// process token transfer(s)
|
327
|
+
if(premiumAmount > 0) {
|
328
|
+
TokenHandler tokenHandler = instance.getTokenHandler(product.productNftId);
|
329
|
+
address policyOwner = _registry.getOwner(policyNftId);
|
330
|
+
address poolWallet = instance.getPoolSetup(product.poolNftId).wallet;
|
331
|
+
netPremiumAmount = premiumAmount;
|
332
|
+
Fee memory policyFee = product.policyFee;
|
333
|
+
|
334
|
+
if (FeeLib.feeIsZero(policyFee)) {
|
335
|
+
tokenHandler.transfer(
|
336
|
+
policyOwner,
|
337
|
+
poolWallet,
|
338
|
+
premiumAmount
|
339
|
+
);
|
340
|
+
} else {
|
341
|
+
(uint256 feeAmount, uint256 netAmount) = instance.calculateFeeAmount(
|
342
|
+
premiumAmount,
|
343
|
+
policyFee
|
344
|
+
);
|
345
|
+
|
346
|
+
tokenHandler.transfer(policyOwner, product.wallet, feeAmount);
|
347
|
+
tokenHandler.transfer(policyOwner, poolWallet, netAmount);
|
348
|
+
netPremiumAmount = netAmount;
|
349
|
+
}
|
350
|
+
}
|
351
|
+
|
352
|
+
// TODO add logging
|
353
|
+
}
|
354
|
+
}
|