@etherisc/gif-next 0.0.2-fe77319 → 0.0.2-fe88ad7-208
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 +364 -8
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +4 -0
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +482 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +675 -0
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +4 -0
- package/artifacts/contracts/{instance/access/Access.sol/AccessModule.json → components/IBaseComponent.sol/IBaseComponent.json} +217 -220
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +152 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +275 -0
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/{instance/pool/PoolModule.sol/PoolModule.json → components/IProductComponent.sol/IProductComponent.json} +81 -86
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +687 -40
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +612 -50
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +66 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +24 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +4 -0
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +42 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +105 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +4 -0
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +105 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +128 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +4 -0
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +42 -0
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +4 -0
- package/artifacts/contracts/experiment/{B.sol → inheritance/B.sol}/B.json +2 -2
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +4 -0
- package/artifacts/contracts/experiment/{C.sol → inheritance/C.sol}/C.json +2 -2
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +4 -0
- package/artifacts/contracts/experiment/{IA.sol → inheritance/IA.sol}/IA.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +4 -0
- package/artifacts/contracts/experiment/{IA.sol → inheritance/IA.sol}/ISharedA.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +4 -0
- package/artifacts/contracts/experiment/{IB.sol → inheritance/IB.sol}/IB.json +1 -1
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +4 -0
- package/artifacts/contracts/experiment/{IC.sol → inheritance/IC.sol}/IC.json +1 -1
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +59 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +74 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +124 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +4 -0
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +207 -0
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +4 -0
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +10 -0
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +4 -0
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +10 -0
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +788 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +185 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1314 -469
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceBase.sol/IInstanceBase.json +448 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +570 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +2531 -505
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +1047 -0
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceBase.sol/InstanceBase.json +763 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1422 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +963 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +460 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +285 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.json +532 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +113 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +429 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.json +115 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +502 -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/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +254 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/{access/IAccess.sol/IAccess.json → module/IBundle.sol/IBundle.json} +2 -2
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.json +10 -0
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module}/IPolicy.sol/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool/IPoolModule.sol/IPool.json → module/IRisk.sol/IRisk.json} +2 -2
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponent.json → module/ISetup.sol/ISetup.json} +2 -2
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +4 -0
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +10 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +945 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +432 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +814 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +693 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +420 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +669 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.json +466 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +446 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +664 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +499 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +536 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +993 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +464 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +727 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +420 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +777 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +420 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +771 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +449 -76
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +976 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +34 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +544 -79
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1195 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +451 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +546 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +397 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.json +107 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +35 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +127 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +201 -0
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/shared/IService.sol/IService.json +421 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +205 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +158 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +349 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +274 -0
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +4 -0
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.json +442 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/shared/Service.sol/Service.json +468 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +96 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +129 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +228 -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/TestRegisterable.sol/TestRegisterable.dbg.json +4 -0
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +305 -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 +600 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +4 -0
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.json +376 -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 +286 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +4 -0
- package/artifacts/contracts/test/Usdc.sol/USDC.json +376 -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 +4 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +174 -0
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +10 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +257 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +125 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +153 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +33 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.json +100 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +92 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +123 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +86 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +156 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +92 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +249 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +479 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionLib.json +177 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +49 -0
- package/contracts/components/BaseComponent.sol +159 -0
- package/contracts/components/Distribution.sol +163 -0
- package/contracts/components/IBaseComponent.sol +34 -0
- package/contracts/components/IDistributionComponent.sol +44 -0
- package/contracts/components/IPoolComponent.sol +66 -0
- package/contracts/components/IProductComponent.sol +35 -0
- package/contracts/components/Pool.sol +260 -18
- package/contracts/components/Product.sol +263 -36
- package/contracts/experiment/cloning/Cloner.sol +47 -0
- package/contracts/experiment/errors/Require.sol +38 -0
- package/contracts/experiment/errors/Revert.sol +44 -0
- package/contracts/experiment/{A.sol → inheritance/A.sol} +8 -11
- package/contracts/experiment/{B.sol → inheritance/B.sol} +10 -5
- package/contracts/experiment/{C.sol → inheritance/C.sol} +11 -5
- package/contracts/experiment/{IA.sol → inheritance/IA.sol} +2 -7
- package/contracts/experiment/{IB.sol → inheritance/IB.sol} +3 -2
- package/contracts/experiment/inheritance/IC.sol +12 -0
- package/contracts/experiment/statemachine/Dummy.sol +27 -0
- package/contracts/experiment/statemachine/ISM.sol +25 -0
- package/contracts/experiment/statemachine/SM.sol +57 -0
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +31 -0
- package/contracts/experiment/types/TypeA.sol +47 -0
- package/contracts/experiment/types/TypeB.sol +29 -0
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +23 -0
- package/contracts/instance/BundleManager.sol +129 -0
- package/contracts/instance/Cloneable.sol +46 -0
- package/contracts/instance/IInstance.sol +57 -15
- package/contracts/instance/IInstanceBase.sol +26 -0
- package/contracts/instance/IInstanceService.sol +40 -0
- package/contracts/instance/Instance.sol +257 -44
- package/contracts/instance/InstanceAccessManager.sol +303 -0
- package/contracts/instance/InstanceBase.sol +41 -0
- package/contracts/instance/InstanceReader.sol +315 -0
- package/contracts/instance/InstanceService.sol +350 -0
- package/contracts/instance/InstanceServiceManager.sol +54 -0
- package/contracts/instance/ObjectManager.sol +101 -0
- package/contracts/instance/base/ComponentServiceBase.sol +82 -0
- package/contracts/instance/base/IInstanceBase.sol +23 -0
- package/contracts/instance/base/IKeyValueStore.sol +49 -0
- package/contracts/instance/base/ILifecycle.sol +30 -0
- package/contracts/instance/base/KeyValueStore.sol +172 -0
- package/contracts/instance/base/Lifecycle.sol +100 -0
- package/contracts/instance/module/IAccess.sol +48 -0
- package/contracts/instance/module/IBundle.sol +20 -0
- package/contracts/instance/module/IDistribution.sol +39 -0
- package/contracts/instance/module/IPolicy.sol +45 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +46 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/instance/service/BundleService.sol +260 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/ComponentOwnerService.sol +315 -0
- package/contracts/instance/service/DistributionService.sol +113 -0
- package/contracts/instance/service/DistributionServiceManager.sol +51 -0
- package/contracts/instance/service/IBundleService.sol +45 -0
- package/contracts/instance/service/IComponentOwnerService.sol +20 -0
- package/contracts/instance/service/IDistributionService.sol +12 -0
- package/contracts/instance/service/IPolicyService.sol +87 -0
- package/contracts/instance/service/IPoolService.sol +20 -0
- package/contracts/instance/service/IProductService.sol +40 -0
- package/contracts/instance/service/PolicyService.sol +503 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +124 -0
- package/contracts/instance/service/PoolServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +170 -0
- package/contracts/instance/service/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +202 -0
- package/contracts/registry/IRegistry.sol +78 -53
- package/contracts/registry/IRegistryService.sol +58 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +329 -130
- package/contracts/registry/RegistryAccessManager.sol +210 -0
- package/contracts/registry/RegistryService.sol +323 -0
- package/contracts/registry/RegistryServiceManager.sol +62 -0
- package/contracts/registry/ReleaseManager.sol +348 -0
- package/contracts/registry/TokenRegistry.sol +110 -0
- package/contracts/shared/ContractDeployerLib.sol +72 -0
- package/contracts/shared/ERC165.sol +25 -0
- package/contracts/shared/INftOwnable.sol +22 -0
- package/contracts/shared/IRegisterable.sol +17 -0
- package/contracts/shared/IService.sol +16 -0
- package/contracts/shared/IVersionable.sol +96 -0
- package/contracts/shared/NftOwnable.sol +134 -0
- package/contracts/shared/ProxyManager.sol +94 -0
- package/contracts/shared/Registerable.sol +90 -0
- package/contracts/shared/RegisterableUpgradable.sol +16 -0
- package/contracts/shared/Service.sol +58 -0
- package/contracts/shared/TokenHandler.sol +27 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +147 -0
- package/contracts/test/TestFee.sol +25 -0
- package/contracts/test/TestRegisterable.sol +18 -0
- package/contracts/test/TestRoleId.sol +14 -0
- package/contracts/test/TestService.sol +25 -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/Blocknumber.sol +118 -0
- package/contracts/types/ChainId.sol +38 -0
- package/contracts/types/DistributorType.sol +55 -0
- package/contracts/types/Fee.sol +56 -0
- package/contracts/types/Key32.sol +50 -0
- package/contracts/types/NftId.sol +72 -0
- package/contracts/types/NftIdSet.sol +62 -0
- package/contracts/types/NumberId.sol +52 -0
- package/contracts/types/ObjectType.sol +152 -0
- package/contracts/types/Referral.sol +85 -0
- package/contracts/types/RiskId.sol +43 -0
- package/contracts/types/RoleId.sol +90 -0
- package/contracts/types/StateId.sol +105 -0
- package/contracts/types/Timestamp.sol +127 -0
- package/contracts/types/UFixed.sol +325 -0
- package/contracts/types/Version.sol +107 -0
- package/package.json +21 -6
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/Component.json +0 -179
- 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/IPool.sol/IPoolComponent.json +0 -179
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +0 -192
- package/artifacts/contracts/experiment/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/IC.sol/IC.dbg.json +0 -4
- 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/access/IAccess.sol/IAccessModule.json +0 -336
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.json +0 -327
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +0 -105
- 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/IComponentContract.json +0 -179
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +0 -245
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +0 -94
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.json +0 -24
- 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/IPolicy.sol/IPolicyModule.json +0 -231
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +0 -231
- 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/IPoolModule.sol/IPoolModule.json +0 -149
- 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 -114
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.json +0 -75
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -125
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.json +0 -24
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.json +0 -166
- 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/Registerable.json +0 -166
- 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 -62
- package/contracts/components/IPool.sol +0 -9
- package/contracts/components/IProduct.sol +0 -11
- package/contracts/experiment/IC.sol +0 -11
- package/contracts/instance/access/Access.sol +0 -218
- package/contracts/instance/access/IAccess.sol +0 -83
- package/contracts/instance/component/ComponentModule.sol +0 -259
- package/contracts/instance/component/IComponent.sol +0 -94
- package/contracts/instance/policy/IPolicy.sol +0 -66
- package/contracts/instance/policy/PolicyModule.sol +0 -106
- package/contracts/instance/pool/IPoolModule.sol +0 -40
- package/contracts/instance/pool/PoolModule.sol +0 -83
- package/contracts/instance/product/IProductService.sol +0 -45
- package/contracts/instance/product/ProductService.sol +0 -105
@@ -1,94 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
|
5
|
-
import {IOwnable, IRegistryLinked, IRegisterable} from "../../registry/IRegistry.sol";
|
6
|
-
import {IInstance} from "../IInstance.sol";
|
7
|
-
|
8
|
-
interface IComponent {
|
9
|
-
|
10
|
-
// TODO decide if enum or uints with constants (as in IRegistry.PRODUCT())
|
11
|
-
enum CState {
|
12
|
-
Undefined,
|
13
|
-
Active,
|
14
|
-
Locked
|
15
|
-
}
|
16
|
-
|
17
|
-
// component dynamic info (static info kept in registry)
|
18
|
-
struct ComponentInfo {
|
19
|
-
uint256 nftId;
|
20
|
-
CState state;
|
21
|
-
}
|
22
|
-
}
|
23
|
-
|
24
|
-
|
25
|
-
interface IInstanceLinked {
|
26
|
-
// function setInstance(address instance) external;
|
27
|
-
function getInstance() external view returns(IInstance instance);
|
28
|
-
}
|
29
|
-
|
30
|
-
|
31
|
-
interface IComponentContract is
|
32
|
-
IRegisterable,
|
33
|
-
IInstanceLinked,
|
34
|
-
IComponent
|
35
|
-
{ }
|
36
|
-
|
37
|
-
|
38
|
-
interface IComponentOwnerService is IRegistryLinked{
|
39
|
-
|
40
|
-
function register(IComponentContract component) external returns(uint256 id);
|
41
|
-
function lock(IComponentContract component) external;
|
42
|
-
function unlock(IComponentContract component) external;
|
43
|
-
}
|
44
|
-
|
45
|
-
|
46
|
-
interface IComponentModule is
|
47
|
-
IOwnable,
|
48
|
-
IRegistryLinked,
|
49
|
-
IComponent
|
50
|
-
{
|
51
|
-
|
52
|
-
function registerComponent(IComponentContract component)
|
53
|
-
external
|
54
|
-
returns(uint256 nftInfo);
|
55
|
-
|
56
|
-
function setComponentInfo(ComponentInfo memory info)
|
57
|
-
external
|
58
|
-
returns(uint256 componentId);
|
59
|
-
|
60
|
-
function getComponentInfo(uint256 id)
|
61
|
-
external
|
62
|
-
view
|
63
|
-
returns(ComponentInfo memory info);
|
64
|
-
|
65
|
-
function getComponentOwner(uint256 id)
|
66
|
-
external
|
67
|
-
view
|
68
|
-
returns(address owner);
|
69
|
-
|
70
|
-
function getComponentId(address componentAddress)
|
71
|
-
external
|
72
|
-
view
|
73
|
-
returns(uint256 id);
|
74
|
-
|
75
|
-
function getComponentId(uint256 idx)
|
76
|
-
external
|
77
|
-
view
|
78
|
-
returns(uint256 id);
|
79
|
-
|
80
|
-
function getPoolNftId(uint256 productNftId)
|
81
|
-
external
|
82
|
-
view
|
83
|
-
returns(uint256 poolNftId);
|
84
|
-
|
85
|
-
function components()
|
86
|
-
external
|
87
|
-
view
|
88
|
-
returns(uint256 numberOfCompnents);
|
89
|
-
|
90
|
-
function getComponentOwnerService()
|
91
|
-
external
|
92
|
-
view
|
93
|
-
returns(IComponentOwnerService);
|
94
|
-
}
|
@@ -1,66 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
|
5
|
-
import {IOwnable, IRegistryLinked, IRegisterable, IRegistry} from "../../registry/IRegistry.sol";
|
6
|
-
import {IInstance} from "../IInstance.sol";
|
7
|
-
|
8
|
-
import {IProductService} from "../product/IProductService.sol";
|
9
|
-
|
10
|
-
// TODO check if there is value to introuce IContract and let IPolicy derive from IContract
|
11
|
-
interface IPolicy {
|
12
|
-
|
13
|
-
enum PolicyState {
|
14
|
-
Undefined,
|
15
|
-
Applied,
|
16
|
-
Rejected,
|
17
|
-
Active,
|
18
|
-
Closed
|
19
|
-
}
|
20
|
-
|
21
|
-
struct PolicyInfo {
|
22
|
-
uint256 nftId;
|
23
|
-
PolicyState state; // applied, withdrawn, rejected, active, closed
|
24
|
-
|
25
|
-
uint256 sumInsuredAmount;
|
26
|
-
uint256 premiumAmount;
|
27
|
-
uint256 lifetime; // activatedAt + lifetime >= expiredAt
|
28
|
-
|
29
|
-
uint256 createdAt;
|
30
|
-
uint256 activatedAt; // time of underwriting
|
31
|
-
uint256 expiredAt; // no new claims
|
32
|
-
uint256 closedAt; // no locked capital
|
33
|
-
}
|
34
|
-
}
|
35
|
-
|
36
|
-
interface IPolicyModule is
|
37
|
-
IOwnable,
|
38
|
-
IRegistryLinked,
|
39
|
-
IPolicy
|
40
|
-
{
|
41
|
-
|
42
|
-
function createApplication(
|
43
|
-
IRegistry.RegistryInfo memory productInfo,
|
44
|
-
address applicationOwner,
|
45
|
-
uint256 sumInsuredAmount,
|
46
|
-
uint256 premiumAmount,
|
47
|
-
uint256 lifetime,
|
48
|
-
uint256 bundleNftId
|
49
|
-
)
|
50
|
-
external
|
51
|
-
returns(uint256 nftId);
|
52
|
-
|
53
|
-
function activate(uint256 nftId)
|
54
|
-
external;
|
55
|
-
|
56
|
-
function getBundleNftForPolicy(uint256 nftId)
|
57
|
-
external
|
58
|
-
view
|
59
|
-
returns(uint256 bundleNft);
|
60
|
-
|
61
|
-
function getPolicyInfo(uint256 nftId)
|
62
|
-
external
|
63
|
-
view
|
64
|
-
returns(PolicyInfo memory info);
|
65
|
-
|
66
|
-
}
|
@@ -1,106 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
|
5
|
-
// import {IOwnable, IRegistryLinked, IRegisterable} from "../../registry/IRegistry.sol";
|
6
|
-
import {IRegistry, IRegistryLinked} from "../../registry/IRegistry.sol";
|
7
|
-
|
8
|
-
import {IProductService} from "../product/IProductService.sol";
|
9
|
-
import {IPolicy, IPolicyModule} from "./IPolicy.sol";
|
10
|
-
|
11
|
-
|
12
|
-
abstract contract PolicyModule is
|
13
|
-
IRegistryLinked,
|
14
|
-
IPolicyModule
|
15
|
-
{
|
16
|
-
|
17
|
-
mapping(uint256 nftId => PolicyInfo info) private _policyInfo;
|
18
|
-
mapping(uint256 nftId => uint256 bundleNftId) private _bundleForPolicy;
|
19
|
-
|
20
|
-
IProductService private _productService;
|
21
|
-
|
22
|
-
// TODO find a better place to avoid dupliation
|
23
|
-
modifier onlyProductService2() {
|
24
|
-
require(address(_productService) == msg.sender, "ERROR:POL-001:NOT_PRODUCT_SERVICE");
|
25
|
-
_;
|
26
|
-
}
|
27
|
-
|
28
|
-
constructor(address productService) {
|
29
|
-
_productService = IProductService(productService);
|
30
|
-
}
|
31
|
-
|
32
|
-
|
33
|
-
function createApplication(
|
34
|
-
IRegistry.RegistryInfo memory productInfo,
|
35
|
-
address applicationOwner,
|
36
|
-
uint256 sumInsuredAmount,
|
37
|
-
uint256 premiumAmount,
|
38
|
-
uint256 lifetime,
|
39
|
-
uint256 bundleNftId
|
40
|
-
)
|
41
|
-
external
|
42
|
-
override
|
43
|
-
onlyProductService2
|
44
|
-
returns(uint256 nftId)
|
45
|
-
{
|
46
|
-
// TODO add parameter validation
|
47
|
-
if(bundleNftId > 0) {
|
48
|
-
IRegistry.RegistryInfo memory bundleInfo = this.getRegistry().getInfo(bundleNftId);
|
49
|
-
IRegistry.RegistryInfo memory poolInfo = this.getRegistry().getInfo(bundleInfo.parentNftId);
|
50
|
-
}
|
51
|
-
|
52
|
-
nftId = this.getRegistry().registerObjectForInstance(
|
53
|
-
productInfo.nftId,
|
54
|
-
this.getRegistry().POLICY(),
|
55
|
-
applicationOwner);
|
56
|
-
|
57
|
-
_policyInfo[nftId] = PolicyInfo(
|
58
|
-
nftId,
|
59
|
-
PolicyState.Applied,
|
60
|
-
sumInsuredAmount,
|
61
|
-
premiumAmount,
|
62
|
-
lifetime,
|
63
|
-
block.timestamp,
|
64
|
-
0, // activatedAt
|
65
|
-
0, // expiredAt
|
66
|
-
0 // closedAt
|
67
|
-
);
|
68
|
-
|
69
|
-
_bundleForPolicy[nftId] = bundleNftId;
|
70
|
-
|
71
|
-
// add logging
|
72
|
-
}
|
73
|
-
|
74
|
-
|
75
|
-
function activate(uint256 nftId)
|
76
|
-
external
|
77
|
-
override
|
78
|
-
onlyProductService2
|
79
|
-
{
|
80
|
-
PolicyInfo storage info = _policyInfo[nftId];
|
81
|
-
info.activatedAt = block.timestamp;
|
82
|
-
info.expiredAt = block.timestamp + info.lifetime;
|
83
|
-
info.state = PolicyState.Active;
|
84
|
-
|
85
|
-
// add logging
|
86
|
-
}
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
function getBundleNftForPolicy(uint256 nftId)
|
91
|
-
external
|
92
|
-
view
|
93
|
-
returns(uint256 bundleNft)
|
94
|
-
{
|
95
|
-
return _bundleForPolicy[nftId];
|
96
|
-
}
|
97
|
-
|
98
|
-
|
99
|
-
function getPolicyInfo(uint256 nftId)
|
100
|
-
external
|
101
|
-
view
|
102
|
-
returns(PolicyInfo memory info)
|
103
|
-
{
|
104
|
-
return _policyInfo[nftId];
|
105
|
-
}
|
106
|
-
}
|
@@ -1,40 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IOwnable, IRegistry, IRegistryLinked} from "../../registry/IRegistry.sol";
|
5
|
-
|
6
|
-
interface IPool {
|
7
|
-
|
8
|
-
struct PoolInfo {
|
9
|
-
uint256 nftId;
|
10
|
-
address wallet;
|
11
|
-
address token;
|
12
|
-
uint256 capital;
|
13
|
-
uint256 lockedCapital;
|
14
|
-
}
|
15
|
-
}
|
16
|
-
|
17
|
-
interface IPoolModule is
|
18
|
-
IOwnable,
|
19
|
-
IRegistryLinked,
|
20
|
-
IPool
|
21
|
-
{
|
22
|
-
|
23
|
-
function underwrite(
|
24
|
-
uint256 poolNftId,
|
25
|
-
uint256 policyNftId
|
26
|
-
)
|
27
|
-
external;
|
28
|
-
|
29
|
-
function createPoolInfo(
|
30
|
-
uint256 nftId,
|
31
|
-
address wallet,
|
32
|
-
address token
|
33
|
-
)
|
34
|
-
external;
|
35
|
-
|
36
|
-
function getPoolInfo(uint256 nftId)
|
37
|
-
external
|
38
|
-
view
|
39
|
-
returns(PoolInfo memory info);
|
40
|
-
}
|
@@ -1,83 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
import {IOwnable, IRegistry, IRegistryLinked} from "../../registry/IRegistry.sol";
|
5
|
-
import {IProductService} from "../product/IProductService.sol";
|
6
|
-
import {IPolicy, IPolicyModule} from "../policy/IPolicy.sol";
|
7
|
-
import {IPoolModule} from "./IPoolModule.sol";
|
8
|
-
|
9
|
-
abstract contract PoolModule is
|
10
|
-
IPoolModule
|
11
|
-
{
|
12
|
-
uint256 public constant INITIAL_CAPITAL = 10000*10**6;
|
13
|
-
|
14
|
-
mapping(uint256 nftId => PoolInfo info) private _poolInfo;
|
15
|
-
|
16
|
-
IProductService private _productService;
|
17
|
-
|
18
|
-
modifier onlyProductService() {
|
19
|
-
require(address(_productService) == msg.sender, "ERROR:POL-001:NOT_PRODUCT_SERVICE");
|
20
|
-
_;
|
21
|
-
}
|
22
|
-
|
23
|
-
constructor(address productService) {
|
24
|
-
_productService = IProductService(productService);
|
25
|
-
}
|
26
|
-
|
27
|
-
function createPoolInfo(
|
28
|
-
uint256 nftId,
|
29
|
-
address wallet,
|
30
|
-
address token
|
31
|
-
)
|
32
|
-
public
|
33
|
-
override
|
34
|
-
{
|
35
|
-
require(
|
36
|
-
_poolInfo[nftId].nftId == 0,
|
37
|
-
"ERROR:PL-001:ALREADY_CREATED");
|
38
|
-
|
39
|
-
_poolInfo[nftId] = PoolInfo(
|
40
|
-
nftId,
|
41
|
-
wallet,
|
42
|
-
token,
|
43
|
-
INITIAL_CAPITAL,
|
44
|
-
0 // locked capital
|
45
|
-
);
|
46
|
-
|
47
|
-
}
|
48
|
-
|
49
|
-
|
50
|
-
function underwrite(
|
51
|
-
uint256 poolNftId,
|
52
|
-
uint256 policyNftId
|
53
|
-
)
|
54
|
-
external
|
55
|
-
override
|
56
|
-
onlyProductService
|
57
|
-
{
|
58
|
-
PoolInfo storage poolInfo = _poolInfo[poolNftId];
|
59
|
-
require(
|
60
|
-
poolInfo.nftId == poolNftId,
|
61
|
-
"ERROR:PL-002:POOL_UNKNOWN");
|
62
|
-
|
63
|
-
IPolicyModule policyModule = IPolicyModule(address(this));
|
64
|
-
IPolicy.PolicyInfo memory policyInfo = policyModule.getPolicyInfo(policyNftId);
|
65
|
-
|
66
|
-
require(
|
67
|
-
poolInfo.capital - poolInfo.lockedCapital >= policyInfo.sumInsuredAmount,
|
68
|
-
"ERROR:PL-003:CAPACITY_TOO_LOW");
|
69
|
-
|
70
|
-
poolInfo.lockedCapital += policyInfo.sumInsuredAmount;
|
71
|
-
}
|
72
|
-
|
73
|
-
|
74
|
-
function getPoolInfo(uint256 nftId)
|
75
|
-
external
|
76
|
-
view
|
77
|
-
override
|
78
|
-
returns(PoolInfo memory info)
|
79
|
-
{
|
80
|
-
info = _poolInfo[nftId];
|
81
|
-
}
|
82
|
-
|
83
|
-
}
|
@@ -1,45 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
|
5
|
-
import {IOwnable, IRegistryLinked, IRegisterable} from "../../registry/IRegistry.sol";
|
6
|
-
import {IInstance} from "../IInstance.sol";
|
7
|
-
|
8
|
-
|
9
|
-
// TODO or name this IProtectionService to have Product be something more generic (loan, savings account, ...)
|
10
|
-
interface IProductService is
|
11
|
-
IRegistryLinked
|
12
|
-
{
|
13
|
-
|
14
|
-
function createApplication(
|
15
|
-
address applicationOwner,
|
16
|
-
uint256 sumInsuredAmount,
|
17
|
-
uint256 premiumAmount,
|
18
|
-
uint256 lifetime,
|
19
|
-
uint256 bundleNftId
|
20
|
-
)
|
21
|
-
external
|
22
|
-
returns(uint256 nftId);
|
23
|
-
|
24
|
-
// function revoke(unit256 nftId) external;
|
25
|
-
|
26
|
-
function underwrite(uint256 nftId) external;
|
27
|
-
// function decline(uint256 nftId) external;
|
28
|
-
// function expire(uint256 nftId) external;
|
29
|
-
function close(uint256 nftId) external;
|
30
|
-
|
31
|
-
// function collectPremium(uint256 nftId, uint256 premiumAmount) external;
|
32
|
-
|
33
|
-
// function createClaim(uint256 nftId, uint256 claimAmount) external;
|
34
|
-
// function confirmClaim(uint256 nftId, uint256 claimId, uint256 claimAmount) external;
|
35
|
-
// function declineClaim(uint256 nftId, uint256 claimId) external;
|
36
|
-
// function closeClaim(uint256 nftId, uint256 claimId) external;
|
37
|
-
}
|
38
|
-
|
39
|
-
|
40
|
-
interface IProductModule is
|
41
|
-
IOwnable,
|
42
|
-
IRegistryLinked
|
43
|
-
{
|
44
|
-
function getProductService() external view returns(IProductService);
|
45
|
-
}
|
@@ -1,105 +0,0 @@
|
|
1
|
-
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.19;
|
3
|
-
|
4
|
-
|
5
|
-
// import {IProduct} from "../../components/IProduct.sol";
|
6
|
-
// import {IOwnable, IRegistryLinked, IRegisterable, IRegistry} from "../../registry/IRegistry.sol";
|
7
|
-
// import {IInstance} from "../IInstance.sol";
|
8
|
-
import {IRegistry} from "../../registry/IRegistry.sol";
|
9
|
-
import {IPolicyModule} from "../policy/IPolicy.sol";
|
10
|
-
import {RegistryLinked} from "../../registry/Registry.sol";
|
11
|
-
import {IProductService, IProductModule} from "./IProductService.sol";
|
12
|
-
import {IComponentModule} from "../../instance/component/IComponent.sol";
|
13
|
-
import {IPoolModule} from "../../instance/pool/IPoolModule.sol";
|
14
|
-
|
15
|
-
// TODO or name this ProtectionService to have Product be something more generic (loan, savings account, ...)
|
16
|
-
contract ProductService is
|
17
|
-
RegistryLinked,
|
18
|
-
IProductService
|
19
|
-
{
|
20
|
-
constructor(address registry)
|
21
|
-
RegistryLinked(registry)
|
22
|
-
{ }
|
23
|
-
|
24
|
-
|
25
|
-
function createApplication(
|
26
|
-
address applicationOwner,
|
27
|
-
uint256 sumInsuredAmount,
|
28
|
-
uint256 premiumAmount,
|
29
|
-
uint256 lifetime,
|
30
|
-
uint256 bundleNftId
|
31
|
-
)
|
32
|
-
external
|
33
|
-
override
|
34
|
-
returns(uint256 nftId)
|
35
|
-
{
|
36
|
-
// same as only registered product
|
37
|
-
uint256 productNftId = _registry.getNftId(msg.sender);
|
38
|
-
require(productNftId > 0, "ERROR_PRODUCT_UNKNOWN");
|
39
|
-
IRegistry.RegistryInfo memory productInfo = _registry.getInfo(productNftId);
|
40
|
-
require(productInfo.objectType == _registry.PRODUCT(), "ERROR_NOT_PRODUCT");
|
41
|
-
|
42
|
-
IRegistry.RegistryInfo memory instanceInfo = _registry.getInfo(productInfo.parentNftId);
|
43
|
-
require(instanceInfo.nftId > 0, "ERROR_INSTANCE_UNKNOWN");
|
44
|
-
require(instanceInfo.objectType == _registry.INSTANCE(), "ERROR_NOT_INSTANCE");
|
45
|
-
|
46
|
-
IPolicyModule policyModule = IPolicyModule(instanceInfo.objectAddress);
|
47
|
-
nftId = policyModule.createApplication(
|
48
|
-
productInfo,
|
49
|
-
applicationOwner,
|
50
|
-
sumInsuredAmount,
|
51
|
-
premiumAmount,
|
52
|
-
lifetime,
|
53
|
-
bundleNftId);
|
54
|
-
|
55
|
-
// add logging
|
56
|
-
}
|
57
|
-
|
58
|
-
function underwrite(uint256 nftId)
|
59
|
-
external
|
60
|
-
override
|
61
|
-
{
|
62
|
-
// same as only registered product
|
63
|
-
uint256 productNftId = _registry.getNftId(msg.sender);
|
64
|
-
require(productNftId > 0, "ERROR_PRODUCT_UNKNOWN");
|
65
|
-
IRegistry.RegistryInfo memory productInfo = _registry.getInfo(productNftId);
|
66
|
-
require(productInfo.objectType == _registry.PRODUCT(), "ERROR_NOT_PRODUCT");
|
67
|
-
|
68
|
-
IRegistry.RegistryInfo memory instanceInfo = _registry.getInfo(productInfo.parentNftId);
|
69
|
-
require(instanceInfo.nftId > 0, "ERROR_INSTANCE_UNKNOWN");
|
70
|
-
require(instanceInfo.objectType == _registry.INSTANCE(), "ERROR_NOT_INSTANCE");
|
71
|
-
|
72
|
-
// get responsible pool
|
73
|
-
IComponentModule componentModule = IComponentModule(instanceInfo.objectAddress);
|
74
|
-
uint256 poolNftId = componentModule.getPoolNftId(productNftId);
|
75
|
-
|
76
|
-
// lock capital (and update pool accounting)
|
77
|
-
IPoolModule poolModule = IPoolModule(instanceInfo.objectAddress);
|
78
|
-
poolModule.underwrite(
|
79
|
-
poolNftId,
|
80
|
-
nftId);
|
81
|
-
|
82
|
-
// activate policy
|
83
|
-
IPolicyModule policyModule = IPolicyModule(instanceInfo.objectAddress);
|
84
|
-
policyModule.activate(nftId);
|
85
|
-
|
86
|
-
// add logging
|
87
|
-
}
|
88
|
-
|
89
|
-
function close(uint256 nftId) external override {}
|
90
|
-
}
|
91
|
-
|
92
|
-
abstract contract ProductModule is
|
93
|
-
IProductModule
|
94
|
-
{
|
95
|
-
IProductService private _productService;
|
96
|
-
|
97
|
-
constructor(address productService) {
|
98
|
-
_productService = IProductService(productService);
|
99
|
-
}
|
100
|
-
|
101
|
-
function getProductService() external view returns(IProductService) {
|
102
|
-
return _productService;
|
103
|
-
}
|
104
|
-
|
105
|
-
}
|