@etherisc/gif-next 0.0.2-f619be3-760 → 0.0.2-f752d2a-551
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 +81 -14
- 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/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/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/{mock → test}/Usdc.sol/USDC.json +3 -3
- 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/ChainId.sol/ChainIdLib.dbg.json +1 -1
- 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 +58 -58
- 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/{mock/Dip.sol → test/TestToken.sol} +5 -5
- package/contracts/test/TestVersion.sol +44 -0
- package/contracts/test/TestVersionable.sol +17 -0
- package/contracts/{mock → test}/Usdc.sol +1 -1
- 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 +12 -13
- package/contracts/types/Version.sol +95 -0
- package/package.json +8 -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/mock/Dip.sol/DIP.dbg.json +0 -4
- package/artifacts/contracts/mock/Dip.sol/DIP.json +0 -338
- package/artifacts/contracts/mock/TestPool.sol/TestPool.dbg.json +0 -4
- package/artifacts/contracts/mock/TestPool.sol/TestPool.json +0 -294
- package/artifacts/contracts/mock/TestProduct.sol/TestProduct.dbg.json +0 -4
- package/artifacts/contracts/mock/TestProduct.sol/TestProduct.json +0 -384
- package/artifacts/contracts/mock/Usdc.sol/USDC.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
- package/contracts/mock/TestPool.sol +0 -16
- package/contracts/mock/TestProduct.sol +0 -39
@@ -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
|
+
}
|
@@ -8,6 +8,9 @@ contract ChainNft is ERC721Enumerable, IChainNft {
|
|
8
8
|
string public constant NAME = "Dezentralized Insurance Protocol Registry";
|
9
9
|
string public constant SYMBOL = "DIPR";
|
10
10
|
|
11
|
+
uint256 public constant PROTOCOL_NFT_ID = 1101;
|
12
|
+
uint256 public constant GLOBAL_REGISTRY_ID = 2101;
|
13
|
+
|
11
14
|
// remember token uri
|
12
15
|
mapping(uint256 tokenId => string uri) private _uri;
|
13
16
|
|
@@ -34,27 +37,34 @@ contract ChainNft is ERC721Enumerable, IChainNft {
|
|
34
37
|
_chainIdInt = block.chainid;
|
35
38
|
_chainIdDigits = _countDigits(_chainIdInt);
|
36
39
|
_chainIdMultiplier = 10 ** _chainIdDigits;
|
37
|
-
|
38
|
-
// on mainnet/goerli start /1 (reserved for protocol nft) on other chains with 2
|
39
|
-
if (block.chainid == 1 || block.chainid == 5) {
|
40
|
-
_idNext = 1;
|
41
|
-
} else {
|
42
|
-
_idNext = 2;
|
43
|
-
}
|
40
|
+
_idNext = 3;
|
44
41
|
}
|
45
42
|
|
43
|
+
/**
|
44
|
+
* @dev mints the next token to register new objects
|
45
|
+
*/
|
46
46
|
function mint(
|
47
47
|
address to,
|
48
48
|
string memory uri
|
49
49
|
) external override onlyRegistry returns (uint256 tokenId) {
|
50
50
|
tokenId = _getNextTokenId();
|
51
|
-
_totalMinted++;
|
52
|
-
|
53
|
-
_safeMint(to, tokenId);
|
54
51
|
|
55
52
|
if (bytes(uri).length > 0) {
|
56
53
|
_uri[tokenId] = uri;
|
57
54
|
}
|
55
|
+
|
56
|
+
_safeMint(to, tokenId);
|
57
|
+
_totalMinted++;
|
58
|
+
}
|
59
|
+
|
60
|
+
/**
|
61
|
+
* @dev mints a token for a specified token id
|
62
|
+
* not part of the IRegistry interface only needed for
|
63
|
+
* initial registry setup (protocol and global registry objects)
|
64
|
+
*/
|
65
|
+
function mint(address to, uint256 tokenId) external onlyRegistry {
|
66
|
+
_totalMinted++;
|
67
|
+
_safeMint(to, tokenId);
|
58
68
|
}
|
59
69
|
|
60
70
|
function burn(uint256 tokenId) external override onlyRegistry {
|
@@ -92,36 +102,50 @@ contract ChainNft is ERC721Enumerable, IChainNft {
|
|
92
102
|
return _totalMinted;
|
93
103
|
}
|
94
104
|
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
105
|
+
/**
|
106
|
+
* @dev token id calculation based on an index value that is supposed
|
107
|
+
* to increase with every minted token
|
108
|
+
*
|
109
|
+
* requirement: each chain registry produces token ids that
|
110
|
+
* are guaranteed to not collide with any token id genereated
|
111
|
+
* on a different chain
|
112
|
+
*
|
113
|
+
* format concat(counter,chainid,2 digits for len-of-chain-id)
|
114
|
+
* restriction chainid up to 99 digits
|
115
|
+
* decode: from right to left:
|
116
|
+
* - 2 right most digits encode length of chainid
|
117
|
+
* - move number of digits to left as determined above (-> chainid)
|
118
|
+
* - the reminder to the left is the counter
|
119
|
+
*
|
120
|
+
* special cases
|
121
|
+
* 1101 -> decentralized insurance protocol
|
122
|
+
* 2102 -> global registry
|
123
|
+
* 2xxxxx -> chain registry, where xxxxx = <chain-part>
|
124
|
+
*
|
125
|
+
* examples
|
126
|
+
* 1101
|
127
|
+
* ^^ ^
|
128
|
+
* || +- 1-digit chain id
|
129
|
+
* |+-- chain id = 1 (mainnet)
|
130
|
+
* +-- 1st token id on mainnet
|
131
|
+
* (1 * 10 ** 1 + 1) * 100 + 1
|
132
|
+
* 42987654321010
|
133
|
+
* ^ ^ ^
|
134
|
+
* | | +- 10-digit chain id
|
135
|
+
* | +-- chain id = 9876543210 (hypothetical chainid)
|
136
|
+
* +-- 42nd token id on this chain
|
137
|
+
* (42 * 10 ** 10 + 9876543210) * 100 + 10
|
138
|
+
* (index * 10 ** digits + chainid) * 100 + digits (1 < digits < 100)
|
139
|
+
*/
|
140
|
+
function calculateTokenId(uint256 idIndex) public view returns (uint256 id) {
|
121
141
|
id =
|
122
|
-
(
|
142
|
+
(idIndex * _chainIdMultiplier + _chainIdInt) *
|
123
143
|
100 +
|
124
144
|
_chainIdDigits;
|
145
|
+
}
|
146
|
+
|
147
|
+
function _getNextTokenId() private returns (uint256 id) {
|
148
|
+
id = calculateTokenId(_idNext);
|
125
149
|
_idNext++;
|
126
150
|
}
|
127
151
|
|
@@ -1,44 +1,21 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
+
import {IERC165} from "@openzeppelin/contracts/utils/introspection/IERC165.sol";
|
5
|
+
|
4
6
|
import {NftId} from "../types/NftId.sol";
|
5
7
|
import {ObjectType} from "../types/ObjectType.sol";
|
8
|
+
import {VersionPart} from "../types/Version.sol";
|
9
|
+
import {IChainNft} from "./IChainNft.sol";
|
6
10
|
|
7
|
-
interface
|
8
|
-
|
9
|
-
}
|
10
|
-
|
11
|
-
interface IRegistryLinked {
|
12
|
-
event LogDebug(uint256 idx, address module, string comment);
|
13
|
-
|
14
|
-
function getRegistry() external view returns (IRegistry registry);
|
15
|
-
}
|
16
|
-
|
17
|
-
interface IRegisterable is IOwnable, IRegistryLinked {
|
18
|
-
function register() external returns (NftId nftId);
|
19
|
-
|
20
|
-
function getNftId() external view returns (NftId nftId);
|
21
|
-
|
22
|
-
function getParentNftId() external view returns (NftId parentNftId);
|
23
|
-
|
24
|
-
function getType() external view returns (ObjectType objectType);
|
25
|
-
|
26
|
-
function getData() external view returns (bytes memory data);
|
27
|
-
|
28
|
-
function isRegisterable() external pure returns (bool);
|
29
|
-
|
30
|
-
function getInitialOwner() external view returns (address initialOwner);
|
31
|
-
|
32
|
-
function isRegistered() external view returns (bool);
|
33
|
-
}
|
34
|
-
|
35
|
-
interface IRegistry {
|
36
|
-
struct RegistryInfo {
|
11
|
+
interface IRegistry is IERC165 {
|
12
|
+
struct ObjectInfo {
|
37
13
|
NftId nftId;
|
38
14
|
NftId parentNftId;
|
39
15
|
ObjectType objectType;
|
40
16
|
address objectAddress;
|
41
17
|
address initialOwner;
|
18
|
+
bytes data;
|
42
19
|
}
|
43
20
|
|
44
21
|
function register(address objectAddress) external returns (NftId nftId);
|
@@ -46,22 +23,35 @@ interface IRegistry {
|
|
46
23
|
function registerObjectForInstance(
|
47
24
|
NftId parentNftid,
|
48
25
|
ObjectType objectType,
|
49
|
-
address initialOwner
|
26
|
+
address initialOwner,
|
27
|
+
bytes memory data
|
50
28
|
) external returns (NftId nftId);
|
51
29
|
|
30
|
+
function getServiceAddress(string memory serviceName, VersionPart majorVersion) external view returns (address serviceAddress);
|
31
|
+
|
52
32
|
function getObjectCount() external view returns (uint256);
|
53
33
|
|
34
|
+
function getNftId() external view returns (NftId nftId);
|
35
|
+
|
54
36
|
function getNftId(
|
55
37
|
address objectAddress
|
56
38
|
) external view returns (NftId nftId);
|
57
39
|
|
58
|
-
function
|
40
|
+
function getObjectInfo(
|
41
|
+
NftId nftId
|
42
|
+
) external view returns (ObjectInfo memory info);
|
43
|
+
|
44
|
+
function getName(
|
59
45
|
NftId nftId
|
60
|
-
) external view returns (
|
46
|
+
) external view returns (string memory name);
|
47
|
+
|
48
|
+
function getProtocolOwner() external view returns (address);
|
61
49
|
|
62
50
|
function getOwner(NftId nftId) external view returns (address ownerAddress);
|
63
51
|
|
52
|
+
function isRegistered(NftId nftId) external view returns (bool);
|
53
|
+
|
64
54
|
function isRegistered(address objectAddress) external view returns (bool);
|
65
55
|
|
66
|
-
function
|
56
|
+
function getChainNft() external view returns (IChainNft);
|
67
57
|
}
|