@etherisc/gif-next 0.0.2-fe77319 → 0.0.2-ff282a4-523
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 +359 -8
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +1376 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1556 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +780 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +1000 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +840 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +284 -523
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +616 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +529 -601
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +1348 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +124 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1574 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +979 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +656 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2847 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +190 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.json +478 -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 +581 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +194 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +237 -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/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponent.json → module/IComponents.sol/IComponents.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/module/ISetup.sol/ISetup.json +10 -0
- 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/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1288 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +696 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +735 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +1095 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1077 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1407 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1622 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +708 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +918 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +648 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1386 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +748 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +493 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +753 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +651 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +510 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +861 -0
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +4 -0
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +442 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1281 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +740 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +688 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1198 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +4 -0
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +864 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +640 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +4 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +784 -0
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +604 -71
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +919 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +52 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +702 -72
- 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 +1211 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +657 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +620 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +485 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/shared/Component.sol/Component.json +873 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +631 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +73 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +636 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +125 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +189 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +175 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{instance/access/IAccess.sol/IAccessCheckRole.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +11 -11
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/shared/IService.sol/IService.json +327 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +55 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +238 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +302 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +569 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +339 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +71 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/shared/Service.sol/Service.json +488 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +114 -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 +78 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +309 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +545 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +497 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +623 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +797 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +632 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +174 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +179 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +312 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +166 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +92 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +142 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +86 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +156 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +92 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +280 -0
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +4 -0
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +10 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +479 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.json +177 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +49 -0
- package/contracts/distribution/Distribution.sol +285 -0
- package/contracts/distribution/DistributionService.sol +349 -0
- package/contracts/distribution/DistributionServiceManager.sol +51 -0
- package/contracts/distribution/IDistributionComponent.sol +71 -0
- package/contracts/distribution/IDistributionService.sol +87 -0
- package/contracts/instance/BundleManager.sol +126 -0
- package/contracts/instance/IInstance.sol +72 -15
- package/contracts/instance/IInstanceService.sol +73 -0
- package/contracts/instance/Instance.sol +210 -44
- package/contracts/instance/InstanceAccessManager.sol +543 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +368 -0
- package/contracts/instance/InstanceService.sol +308 -0
- package/contracts/instance/InstanceServiceManager.sol +54 -0
- package/contracts/instance/InstanceStore.sol +211 -0
- package/contracts/instance/base/Cloneable.sol +51 -0
- package/contracts/instance/base/IKeyValueStore.sol +53 -0
- package/contracts/instance/base/ILifecycle.sol +30 -0
- package/contracts/instance/base/KeyValueStore.sol +169 -0
- package/contracts/instance/base/Lifecycle.sol +121 -0
- package/contracts/instance/base/ObjectManager.sol +82 -0
- package/contracts/instance/module/IAccess.sol +54 -0
- package/contracts/instance/module/IBundle.sol +23 -0
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +42 -0
- package/contracts/instance/module/IPolicy.sol +78 -0
- package/contracts/instance/module/IRisk.sol +11 -0
- package/contracts/instance/module/ISetup.sol +33 -0
- package/contracts/instance/module/ITreasury.sol +23 -0
- package/contracts/pool/BundleService.sol +382 -0
- package/contracts/pool/BundleServiceManager.sol +51 -0
- package/contracts/pool/IBundleService.sol +118 -0
- package/contracts/pool/IPoolComponent.sol +114 -0
- package/contracts/pool/IPoolService.sol +114 -0
- package/contracts/pool/Pool.sol +302 -0
- package/contracts/pool/PoolService.sol +403 -0
- package/contracts/pool/PoolServiceManager.sol +51 -0
- package/contracts/product/ApplicationService.sol +186 -0
- package/contracts/product/ApplicationServiceManager.sol +35 -0
- package/contracts/product/ClaimService.sol +442 -0
- package/contracts/product/ClaimServiceManager.sol +35 -0
- package/contracts/product/IApplicationService.sol +62 -0
- package/contracts/product/IClaimService.sol +93 -0
- package/contracts/product/IPolicyService.sol +80 -0
- package/contracts/product/IPricingService.sol +37 -0
- package/contracts/product/IProductComponent.sol +41 -0
- package/contracts/product/IProductService.sol +40 -0
- package/contracts/product/PolicyService.sol +376 -0
- package/contracts/product/PolicyServiceManager.sol +54 -0
- package/contracts/product/PricingService.sol +275 -0
- package/contracts/product/PricingServiceManager.sol +51 -0
- package/contracts/product/Product.sol +379 -0
- package/contracts/product/ProductService.sol +210 -0
- package/contracts/product/ProductServiceManager.sol +54 -0
- package/contracts/registry/ChainNft.sol +216 -0
- package/contracts/registry/IRegistry.sol +95 -51
- package/contracts/registry/IRegistryService.sol +69 -0
- package/contracts/registry/ITransferInterceptor.sol +7 -0
- package/contracts/registry/Registry.sol +436 -128
- package/contracts/registry/RegistryAccessManager.sol +207 -0
- package/contracts/registry/RegistryService.sol +304 -0
- package/contracts/registry/RegistryServiceManager.sol +60 -0
- package/contracts/registry/ReleaseManager.sol +360 -0
- package/contracts/registry/TokenRegistry.sol +116 -0
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/Component.sol +271 -0
- package/contracts/shared/ComponentService.sol +150 -0
- package/contracts/shared/ERC165.sol +27 -0
- package/contracts/shared/IComponent.sol +90 -0
- package/contracts/shared/INftOwnable.sol +23 -0
- package/contracts/shared/IPolicyHolder.sol +40 -0
- package/contracts/shared/IRegisterable.sol +15 -0
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +18 -0
- package/contracts/shared/IVersionable.sol +53 -0
- package/contracts/shared/NftOwnable.sol +118 -0
- package/contracts/shared/PolicyHolder.sol +94 -0
- package/contracts/shared/ProxyManager.sol +169 -0
- package/contracts/shared/Registerable.sol +75 -0
- package/contracts/shared/RegistryLinked.sol +43 -0
- package/contracts/shared/Service.sol +72 -0
- package/contracts/shared/TokenHandler.sol +35 -0
- package/contracts/shared/UpgradableProxyWithAdmin.sol +16 -0
- package/contracts/shared/Versionable.sol +59 -0
- package/contracts/staking/IStaking.sol +15 -0
- package/contracts/staking/IStakingService.sol +105 -0
- package/contracts/staking/Staking.sol +64 -0
- package/contracts/staking/StakingManager.sol +44 -0
- package/contracts/staking/StakingService.sol +204 -0
- package/contracts/staking/StakingServiceManager.sol +41 -0
- package/contracts/type/AddressSet.sol +58 -0
- package/contracts/type/Amount.sol +109 -0
- package/contracts/type/Blocknumber.sol +119 -0
- package/contracts/type/ClaimId.sol +75 -0
- package/contracts/type/DistributorType.sol +55 -0
- package/contracts/type/Fee.sol +65 -0
- package/contracts/type/Key32.sol +50 -0
- package/contracts/type/NftId.sol +80 -0
- package/contracts/type/NftIdSet.sol +62 -0
- package/contracts/type/ObjectType.sol +166 -0
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/type/Referral.sol +89 -0
- package/contracts/type/RiskId.sol +43 -0
- package/contracts/type/RoleId.sol +132 -0
- package/contracts/type/Seconds.sol +54 -0
- package/contracts/type/StateId.sol +110 -0
- package/contracts/type/Timestamp.sol +132 -0
- package/contracts/type/UFixed.sol +326 -0
- package/contracts/type/Version.sol +108 -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/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -195
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -213
- 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/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/IC.sol/IC.json +0 -63
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.json +0 -400
- 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/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/pool/PoolModule.sol/PoolModule.json +0 -162
- 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/components/Pool.sol +0 -29
- package/contracts/components/Product.sol +0 -65
- package/contracts/experiment/A.sol +0 -56
- package/contracts/experiment/B.sol +0 -23
- package/contracts/experiment/C.sol +0 -28
- package/contracts/experiment/IA.sol +0 -18
- package/contracts/experiment/IB.sol +0 -9
- 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
@@ -0,0 +1,30 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {NftId} from "../../type/NftId.sol";
|
5
|
+
import {ObjectType} from "../../type/ObjectType.sol";
|
6
|
+
import {StateId} from "../../type/StateId.sol";
|
7
|
+
|
8
|
+
interface ILifecycle {
|
9
|
+
|
10
|
+
error ErrorNoLifecycle(NftId nftId, ObjectType objectType);
|
11
|
+
error ErrorInvalidStateTransition(
|
12
|
+
ObjectType objectType,
|
13
|
+
StateId fromStateId,
|
14
|
+
StateId toStateId
|
15
|
+
);
|
16
|
+
|
17
|
+
function hasLifecycle(
|
18
|
+
ObjectType objectType
|
19
|
+
) external view returns (bool);
|
20
|
+
|
21
|
+
function getInitialState(
|
22
|
+
ObjectType objectType
|
23
|
+
) external view returns (StateId);
|
24
|
+
|
25
|
+
function isValidTransition(
|
26
|
+
ObjectType objectType,
|
27
|
+
StateId fromId,
|
28
|
+
StateId toId
|
29
|
+
) external view returns (bool);
|
30
|
+
}
|
@@ -0,0 +1,169 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Blocknumber, blockBlocknumber, zeroBlocknumber} from "../../type/Blocknumber.sol";
|
5
|
+
import {Key32, KeyId, Key32Lib} from "../../type/Key32.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {ObjectType} from "../../type/ObjectType.sol";
|
8
|
+
import {StateId, ACTIVE, KEEP_STATE} from "../../type/StateId.sol";
|
9
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
10
|
+
|
11
|
+
import {Lifecycle} from "./Lifecycle.sol";
|
12
|
+
import {IKeyValueStore} from "./IKeyValueStore.sol";
|
13
|
+
|
14
|
+
contract KeyValueStore is
|
15
|
+
Lifecycle,
|
16
|
+
IKeyValueStore
|
17
|
+
{
|
18
|
+
|
19
|
+
mapping(Key32 key32 => Value value) private _value;
|
20
|
+
|
21
|
+
function create(
|
22
|
+
Key32 key32,
|
23
|
+
bytes memory data
|
24
|
+
)
|
25
|
+
internal
|
26
|
+
{
|
27
|
+
ObjectType objectType = key32.toObjectType();
|
28
|
+
if (objectType.eqz()) {
|
29
|
+
revert ErrorKeyValueStoreTypeUndefined(objectType);
|
30
|
+
}
|
31
|
+
|
32
|
+
Metadata storage metadata = _value[key32].metadata;
|
33
|
+
if (metadata.state.gtz()) {
|
34
|
+
revert ErrorKeyValueStoreAlreadyCreated(key32, objectType);
|
35
|
+
}
|
36
|
+
|
37
|
+
address createdBy = msg.sender;
|
38
|
+
Blocknumber blocknumber = blockBlocknumber();
|
39
|
+
StateId initialState = hasLifecycle(objectType) ? getInitialState(objectType) : ACTIVE();
|
40
|
+
|
41
|
+
// set metadata
|
42
|
+
metadata.objectType = objectType;
|
43
|
+
metadata.state = initialState;
|
44
|
+
metadata.updatedBy = createdBy;
|
45
|
+
metadata.updatedIn = blocknumber;
|
46
|
+
metadata.createdIn = blocknumber;
|
47
|
+
|
48
|
+
// set data
|
49
|
+
_value[key32].data = data;
|
50
|
+
|
51
|
+
// solhint-disable-next-line avoid-tx-origin
|
52
|
+
emit LogInfoCreated(key32.toObjectType(), key32.toKeyId(), initialState, createdBy, tx.origin);
|
53
|
+
}
|
54
|
+
|
55
|
+
function update(
|
56
|
+
Key32 key32,
|
57
|
+
bytes memory data,
|
58
|
+
StateId state
|
59
|
+
)
|
60
|
+
internal
|
61
|
+
{
|
62
|
+
if (state.eqz()) {
|
63
|
+
revert ErrorKeyValueStoreStateZero(key32);
|
64
|
+
}
|
65
|
+
|
66
|
+
Metadata storage metadata = _value[key32].metadata;
|
67
|
+
StateId stateOld = metadata.state;
|
68
|
+
if (stateOld.eqz()) {
|
69
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
70
|
+
}
|
71
|
+
|
72
|
+
// update data
|
73
|
+
_value[key32].data = data;
|
74
|
+
|
75
|
+
// update state
|
76
|
+
if(state != KEEP_STATE()) {
|
77
|
+
checkTransition(metadata.objectType, stateOld, state);
|
78
|
+
metadata.state = state;
|
79
|
+
}
|
80
|
+
|
81
|
+
// update reest of metadata
|
82
|
+
address updatedBy = msg.sender;
|
83
|
+
Blocknumber lastUpdatedIn = metadata.updatedIn;
|
84
|
+
|
85
|
+
metadata.updatedBy = updatedBy;
|
86
|
+
metadata.updatedIn = blockBlocknumber();
|
87
|
+
|
88
|
+
// create log entries
|
89
|
+
// solhint-disable avoid-tx-origin
|
90
|
+
emit LogStateUpdated(key32.toObjectType(), key32.toKeyId(), stateOld, state, updatedBy, tx.origin, lastUpdatedIn);
|
91
|
+
emit LogInfoUpdated(key32.toObjectType(), key32.toKeyId(), state, updatedBy, tx.origin, lastUpdatedIn);
|
92
|
+
// solhing-enable
|
93
|
+
}
|
94
|
+
|
95
|
+
function updateData(Key32 key32, bytes memory data)
|
96
|
+
internal
|
97
|
+
{
|
98
|
+
Metadata storage metadata = _value[key32].metadata;
|
99
|
+
StateId state = metadata.state;
|
100
|
+
if (state.eqz()) {
|
101
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
102
|
+
}
|
103
|
+
|
104
|
+
// update data
|
105
|
+
_value[key32].data = data;
|
106
|
+
|
107
|
+
// update metadata
|
108
|
+
address updatedBy = msg.sender;
|
109
|
+
Blocknumber lastUpdatedIn = metadata.updatedIn;
|
110
|
+
metadata.updatedBy = updatedBy;
|
111
|
+
metadata.updatedIn = blockBlocknumber();
|
112
|
+
|
113
|
+
// create log entry
|
114
|
+
// solhint-disable-next-line avoid-tx-origin
|
115
|
+
emit LogInfoUpdated(key32.toObjectType(), key32.toKeyId(), state, updatedBy, tx.origin, lastUpdatedIn);
|
116
|
+
}
|
117
|
+
|
118
|
+
function updateState(Key32 key32, StateId state)
|
119
|
+
internal
|
120
|
+
{
|
121
|
+
if (state.eqz()) {
|
122
|
+
revert ErrorKeyValueStoreStateZero(key32);
|
123
|
+
}
|
124
|
+
|
125
|
+
Metadata storage metadata = _value[key32].metadata;
|
126
|
+
StateId stateOld = metadata.state;
|
127
|
+
if (stateOld.eqz()) {
|
128
|
+
revert ErrorKeyValueStoreNotExisting(key32);
|
129
|
+
}
|
130
|
+
|
131
|
+
// ensure state transistion is valid
|
132
|
+
checkTransition(metadata.objectType, stateOld, state);
|
133
|
+
|
134
|
+
// update metadata (and state)
|
135
|
+
address updatedBy = msg.sender;
|
136
|
+
Blocknumber lastUpdatedIn = metadata.updatedIn;
|
137
|
+
metadata.state = state;
|
138
|
+
metadata.updatedBy = updatedBy;
|
139
|
+
metadata.updatedIn = blockBlocknumber();
|
140
|
+
|
141
|
+
// create log entry
|
142
|
+
// solhint-disable-next-line avoid-tx-origin
|
143
|
+
emit LogStateUpdated(key32.toObjectType(), key32.toKeyId(), stateOld, state, updatedBy, tx.origin, lastUpdatedIn);
|
144
|
+
}
|
145
|
+
|
146
|
+
function exists(Key32 key32) public view returns (bool) {
|
147
|
+
return _value[key32].metadata.state.gtz();
|
148
|
+
}
|
149
|
+
|
150
|
+
function get(Key32 key32) public view returns (Value memory value) {
|
151
|
+
return _value[key32];
|
152
|
+
}
|
153
|
+
|
154
|
+
function getMetadata(Key32 key32) public view returns (Metadata memory metadata) {
|
155
|
+
return _value[key32].metadata;
|
156
|
+
}
|
157
|
+
|
158
|
+
function getData(Key32 key32) public view returns (bytes memory data) {
|
159
|
+
return _value[key32].data;
|
160
|
+
}
|
161
|
+
|
162
|
+
function getState(Key32 key32) public view returns (StateId state) {
|
163
|
+
return _value[key32].metadata.state;
|
164
|
+
}
|
165
|
+
|
166
|
+
function toKey32(ObjectType objectType, KeyId id) external pure override returns(Key32) {
|
167
|
+
return Key32Lib.toKey32(objectType, id);
|
168
|
+
}
|
169
|
+
}
|
@@ -0,0 +1,121 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Initializable} from "@openzeppelin/contracts-upgradeable/proxy/utils/Initializable.sol";
|
5
|
+
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {ObjectType, COMPONENT, BUNDLE, POLICY, RISK, CLAIM, PAYOUT} from "../../type/ObjectType.sol";
|
8
|
+
import {StateId, ACTIVE, PAUSED, ARCHIVED, CLOSED, APPLIED, COLLATERALIZED, REVOKED, SUBMITTED, CONFIRMED, DECLINED, EXPECTED, PAID} from "../../type/StateId.sol";
|
9
|
+
import {ILifecycle} from "./ILifecycle.sol";
|
10
|
+
|
11
|
+
contract Lifecycle is
|
12
|
+
Initializable,
|
13
|
+
ILifecycle
|
14
|
+
{
|
15
|
+
mapping(ObjectType objectType => StateId initialState)
|
16
|
+
private _initialState;
|
17
|
+
|
18
|
+
mapping(ObjectType objectType => mapping(StateId stateFrom => mapping(StateId stateTo => bool isValid)))
|
19
|
+
private _isValidTransition;
|
20
|
+
|
21
|
+
function initializeLifecycle()
|
22
|
+
public
|
23
|
+
onlyInitializing
|
24
|
+
{
|
25
|
+
_setupBundleLifecycle();
|
26
|
+
_setupComponentLifecycle();
|
27
|
+
_setupPolicyLifecycle();
|
28
|
+
_setupClaimAndPayoutLifecycle();
|
29
|
+
_setupRiskLifecycle();
|
30
|
+
}
|
31
|
+
|
32
|
+
function hasLifecycle(
|
33
|
+
ObjectType objectType
|
34
|
+
)
|
35
|
+
public
|
36
|
+
view
|
37
|
+
override
|
38
|
+
returns (bool)
|
39
|
+
{
|
40
|
+
return _initialState[objectType].gtz();
|
41
|
+
}
|
42
|
+
|
43
|
+
function getInitialState(
|
44
|
+
ObjectType objectType
|
45
|
+
)
|
46
|
+
public
|
47
|
+
view
|
48
|
+
returns (StateId)
|
49
|
+
{
|
50
|
+
return _initialState[objectType];
|
51
|
+
}
|
52
|
+
|
53
|
+
function checkTransition(
|
54
|
+
ObjectType objectType,
|
55
|
+
StateId fromId,
|
56
|
+
StateId toId
|
57
|
+
)
|
58
|
+
public
|
59
|
+
view
|
60
|
+
{
|
61
|
+
// return if no life cycle support
|
62
|
+
if (_initialState[objectType].eqz()) {
|
63
|
+
return;
|
64
|
+
}
|
65
|
+
|
66
|
+
// enforce valid state transition
|
67
|
+
if (!_isValidTransition[objectType][fromId][toId]) {
|
68
|
+
revert ErrorInvalidStateTransition(objectType, fromId, toId);
|
69
|
+
}
|
70
|
+
}
|
71
|
+
|
72
|
+
function isValidTransition(
|
73
|
+
ObjectType objectType,
|
74
|
+
StateId fromId,
|
75
|
+
StateId toId
|
76
|
+
) public view returns (bool) {
|
77
|
+
return _isValidTransition[objectType][fromId][toId];
|
78
|
+
}
|
79
|
+
|
80
|
+
function _setupComponentLifecycle() internal {
|
81
|
+
_initialState[COMPONENT()] = ACTIVE();
|
82
|
+
_isValidTransition[COMPONENT()][ACTIVE()][PAUSED()] = true;
|
83
|
+
_isValidTransition[COMPONENT()][PAUSED()][ACTIVE()] = true;
|
84
|
+
_isValidTransition[COMPONENT()][PAUSED()][ARCHIVED()] = true;
|
85
|
+
}
|
86
|
+
|
87
|
+
function _setupBundleLifecycle() internal {
|
88
|
+
_initialState[BUNDLE()] = ACTIVE();
|
89
|
+
_isValidTransition[BUNDLE()][ACTIVE()][PAUSED()] = true;
|
90
|
+
_isValidTransition[BUNDLE()][ACTIVE()][CLOSED()] = true;
|
91
|
+
_isValidTransition[BUNDLE()][PAUSED()][ACTIVE()] = true;
|
92
|
+
_isValidTransition[BUNDLE()][PAUSED()][CLOSED()] = true;
|
93
|
+
}
|
94
|
+
|
95
|
+
function _setupPolicyLifecycle() internal {
|
96
|
+
_initialState[POLICY()] = APPLIED();
|
97
|
+
_isValidTransition[POLICY()][APPLIED()][REVOKED()] = true;
|
98
|
+
_isValidTransition[POLICY()][APPLIED()][DECLINED()] = true;
|
99
|
+
_isValidTransition[POLICY()][APPLIED()][COLLATERALIZED()] = true;
|
100
|
+
_isValidTransition[POLICY()][APPLIED()][ACTIVE()] = true;
|
101
|
+
_isValidTransition[POLICY()][COLLATERALIZED()][ACTIVE()] = true;
|
102
|
+
_isValidTransition[POLICY()][ACTIVE()][CLOSED()] = true;
|
103
|
+
}
|
104
|
+
|
105
|
+
function _setupClaimAndPayoutLifecycle() internal {
|
106
|
+
_initialState[CLAIM()] = SUBMITTED();
|
107
|
+
_isValidTransition[CLAIM()][SUBMITTED()][CONFIRMED()] = true;
|
108
|
+
_isValidTransition[CLAIM()][SUBMITTED()][DECLINED()] = true;
|
109
|
+
_isValidTransition[CLAIM()][CONFIRMED()][CLOSED()] = true;
|
110
|
+
|
111
|
+
_initialState[PAYOUT()] = EXPECTED();
|
112
|
+
_isValidTransition[PAYOUT()][EXPECTED()][PAID()] = true;
|
113
|
+
}
|
114
|
+
|
115
|
+
function _setupRiskLifecycle() internal {
|
116
|
+
_initialState[RISK()] = ACTIVE();
|
117
|
+
_isValidTransition[RISK()][ACTIVE()][PAUSED()] = true;
|
118
|
+
_isValidTransition[RISK()][PAUSED()][ACTIVE()] = true;
|
119
|
+
_isValidTransition[RISK()][PAUSED()][ARCHIVED()] = true;
|
120
|
+
}
|
121
|
+
}
|
@@ -0,0 +1,82 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Cloneable} from "./Cloneable.sol";
|
5
|
+
|
6
|
+
import {IInstance} from "../IInstance.sol";
|
7
|
+
import {INSTANCE} from "../../type/ObjectType.sol";
|
8
|
+
import {InstanceReader} from "../InstanceReader.sol";
|
9
|
+
import {IRegistry} from "../../registry/IRegistry.sol";
|
10
|
+
import {LibNftIdSet} from "../../type/NftIdSet.sol";
|
11
|
+
import {NftId} from "../../type/NftId.sol";
|
12
|
+
|
13
|
+
contract ObjectManager is
|
14
|
+
Cloneable
|
15
|
+
{
|
16
|
+
|
17
|
+
event LogObjectManagerInitialized(address instance);
|
18
|
+
|
19
|
+
error ErrorObjectManagerNftIdInvalid(NftId instanceNftId);
|
20
|
+
error ErrorObjectManagerAlreadyAdded(NftId componentNftId, NftId objectNftId);
|
21
|
+
|
22
|
+
mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _activeObjects;
|
23
|
+
mapping(NftId compnentNftId => LibNftIdSet.Set objects) internal _allObjects;
|
24
|
+
IInstance internal _instance; // store instance address -> more flexible, instance may not be registered during ObjectManager initialization
|
25
|
+
|
26
|
+
/// @dev call to initialize MUST be made in the same transaction as cloning of the contract
|
27
|
+
function initialize(address instanceAddress)
|
28
|
+
initializer
|
29
|
+
external
|
30
|
+
{
|
31
|
+
IInstance instance = IInstance(instanceAddress);
|
32
|
+
initialize(instance.authority(), address(instance.getRegistry()));
|
33
|
+
|
34
|
+
_instance = instance;
|
35
|
+
|
36
|
+
emit LogObjectManagerInitialized(instanceAddress);
|
37
|
+
}
|
38
|
+
|
39
|
+
function getInstance() external view returns (IInstance) {
|
40
|
+
return _instance;
|
41
|
+
}
|
42
|
+
|
43
|
+
function _add(NftId componentNftId, NftId objectNftId) internal {
|
44
|
+
LibNftIdSet.Set storage allSet = _allObjects[componentNftId];
|
45
|
+
LibNftIdSet.Set storage activeSet = _activeObjects[componentNftId];
|
46
|
+
|
47
|
+
LibNftIdSet.add(allSet, objectNftId);
|
48
|
+
LibNftIdSet.add(activeSet, objectNftId);
|
49
|
+
}
|
50
|
+
|
51
|
+
function _activate(NftId componentNftId, NftId objectNftId) internal {
|
52
|
+
LibNftIdSet.add(_activeObjects[componentNftId], objectNftId);
|
53
|
+
}
|
54
|
+
|
55
|
+
function _deactivate(NftId componentNftId, NftId objectNftId) internal {
|
56
|
+
LibNftIdSet.remove(_activeObjects[componentNftId], objectNftId);
|
57
|
+
}
|
58
|
+
|
59
|
+
function _objects(NftId componentNftId) internal view returns (uint256) {
|
60
|
+
return LibNftIdSet.size(_allObjects[componentNftId]);
|
61
|
+
}
|
62
|
+
|
63
|
+
function _contains(NftId componentNftId, NftId objectNftId) internal view returns (bool) {
|
64
|
+
return LibNftIdSet.contains(_allObjects[componentNftId], objectNftId);
|
65
|
+
}
|
66
|
+
|
67
|
+
function _getObject(NftId componentNftId, uint256 idx) internal view returns (NftId) {
|
68
|
+
return LibNftIdSet.getElementAt(_allObjects[componentNftId], idx);
|
69
|
+
}
|
70
|
+
|
71
|
+
function _activeObjs(NftId componentNftId) internal view returns (uint256) {
|
72
|
+
return LibNftIdSet.size(_activeObjects[componentNftId]);
|
73
|
+
}
|
74
|
+
|
75
|
+
function _isActive(NftId componentNftId, NftId objectNftId) internal view returns (bool) {
|
76
|
+
return LibNftIdSet.contains(_activeObjects[componentNftId], objectNftId);
|
77
|
+
}
|
78
|
+
|
79
|
+
function _getActiveObject(NftId componentNftId, uint256 idx) internal view returns (NftId) {
|
80
|
+
return LibNftIdSet.getElementAt(_activeObjects[componentNftId], idx);
|
81
|
+
}
|
82
|
+
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
|
5
|
+
|
6
|
+
import {RoleId} from "../../type/RoleId.sol";
|
7
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
8
|
+
|
9
|
+
interface IAccess {
|
10
|
+
|
11
|
+
enum Type {
|
12
|
+
NotInitialized,
|
13
|
+
Core,
|
14
|
+
Gif,
|
15
|
+
Custom
|
16
|
+
}
|
17
|
+
|
18
|
+
struct RoleInfo {
|
19
|
+
ShortString name;
|
20
|
+
Type rtype;
|
21
|
+
//bool isLocked;
|
22
|
+
RoleId admin;
|
23
|
+
Timestamp createdAt;
|
24
|
+
Timestamp updatedAt;
|
25
|
+
}
|
26
|
+
|
27
|
+
struct TargetInfo {
|
28
|
+
ShortString name;
|
29
|
+
Type ttype;
|
30
|
+
bool isLocked;
|
31
|
+
Timestamp createdAt;
|
32
|
+
Timestamp updatedAt;
|
33
|
+
}
|
34
|
+
|
35
|
+
error ErrorIAccessCallerIsNotRoleAdmin(address caller, RoleId roleId);
|
36
|
+
|
37
|
+
error ErrorIAccessRoleIdDoesNotExist(RoleId roleId);
|
38
|
+
error ErrorIAccessRoleIdTooBig(RoleId roleId);
|
39
|
+
error ErrorIAccessRoleIdTooSmall(RoleId roleId);
|
40
|
+
error ErrorIAccessRoleIdExists(RoleId roleId);
|
41
|
+
error ErrorIAccessRoleNameEmpty(RoleId roleId);
|
42
|
+
error ErrorIAccessRoleNameExists(RoleId roleId, RoleId existingRoleId, ShortString name);
|
43
|
+
error ErrorIAccessRoleTypeInvalid(RoleId roleId, Type rtype);
|
44
|
+
|
45
|
+
error ErrorIAccessTargetAddressZero();
|
46
|
+
error ErrorIAccessTargetDoesNotExist(address target);
|
47
|
+
error ErrorIAccessTargetExists(address target, ShortString name);
|
48
|
+
error ErrorIAccessTargetTypeInvalid(address target, Type ttype);
|
49
|
+
error ErrorIAccessTargetNameEmpty(address target);
|
50
|
+
error ErrorIAccessTargetNameExists(address target, address existingTarget, ShortString name);
|
51
|
+
error ErrorIAccessTargetLocked(address target);
|
52
|
+
error ErrorIAccessTargetNotRegistered(address target);
|
53
|
+
error ErrorIAccessTargetAuthorityInvalid(address target, address targetAuthority);
|
54
|
+
}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {NftId} from "../../type/NftId.sol";
|
6
|
+
import {Fee} from "../../type/Fee.sol";
|
7
|
+
import {Seconds} from "../../type/Seconds.sol";
|
8
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
9
|
+
|
10
|
+
interface IBundle {
|
11
|
+
|
12
|
+
struct BundleInfo {
|
13
|
+
NftId poolNftId;
|
14
|
+
Fee fee; // bundle fee on net premium amounts
|
15
|
+
bytes filter; // required conditions for applications to be considered for collateralization by this bundle
|
16
|
+
Amount capitalAmount; // net stakings + net premiums - payouts
|
17
|
+
Amount lockedAmount; // capital amount linked to collateralizaion of non-closed policies (<= capital amount)
|
18
|
+
Amount feeAmount; // accumulated fee amount
|
19
|
+
Seconds lifetime;
|
20
|
+
Timestamp expiredAt; // no new policies starting with this timestamp
|
21
|
+
Timestamp closedAt; // no open policies, locked amount = 0
|
22
|
+
}
|
23
|
+
}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
6
|
+
import {Amount} from "../../type/Amount.sol";
|
7
|
+
import {Fee} from "../../type/Fee.sol";
|
8
|
+
import {NftId} from "../../type/NftId.sol";
|
9
|
+
import {RoleId} from "../../type/RoleId.sol";
|
10
|
+
import {TokenHandler} from "../../shared/TokenHandler.sol";
|
11
|
+
import {UFixed} from "../../type/UFixed.sol";
|
12
|
+
|
13
|
+
interface IComponents {
|
14
|
+
|
15
|
+
struct ComponentInfo {
|
16
|
+
string name; // component name (needs to be unique per instance)
|
17
|
+
IERC20Metadata token;
|
18
|
+
TokenHandler tokenHandler;
|
19
|
+
address wallet;
|
20
|
+
Amount balanceAmount; // calculated balance (may not necessarily match withg wallet balance)
|
21
|
+
Amount feeAmount; // accumulated fees belonging to component owner
|
22
|
+
bytes data; // will hold component type specific additional info (eg encoded pool info)
|
23
|
+
}
|
24
|
+
|
25
|
+
struct PoolInfo {
|
26
|
+
NftId productNftId; // the nft of the product this pool is linked to
|
27
|
+
RoleId bundleOwnerRole; // the required role for bundle owners
|
28
|
+
// TODO maxCapitalAmount -> maxBalanceAmount
|
29
|
+
Amount maxCapitalAmount; // max capital amount allowed for pool
|
30
|
+
Amount balanceAmount; // current pool balance (accounting view)
|
31
|
+
Amount feeAmount; // accumulated fee amount
|
32
|
+
bool isInterceptingBundleTransfers; // intercepts nft transfers for bundles
|
33
|
+
bool isExternallyManaged; // funding bundles is restricted to book keeping, actual funds may be provided as needed to support payouts
|
34
|
+
bool isVerifyingApplications; // underwriting requires the pool component checks/confirms the applications
|
35
|
+
UFixed collateralizationLevel; // factor to calculate collateral for sum insurance (default 100%)
|
36
|
+
UFixed retentionLevel; // amount of collateral held in pool (default 100%)
|
37
|
+
Fee poolFee; // pool fee on net premium
|
38
|
+
Fee stakingFee; // pool fee on staked capital from investor
|
39
|
+
Fee performanceFee; // pool fee on profits from capital investors
|
40
|
+
}
|
41
|
+
}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {DistributorType} from "../../type/DistributorType.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
8
|
+
import {UFixed} from "../../type/UFixed.sol";
|
9
|
+
|
10
|
+
interface IDistribution {
|
11
|
+
|
12
|
+
struct DistributorTypeInfo {
|
13
|
+
string name;
|
14
|
+
UFixed minDiscountPercentage;
|
15
|
+
UFixed maxDiscountPercentage;
|
16
|
+
UFixed commissionPercentage;
|
17
|
+
uint32 maxReferralCount;
|
18
|
+
uint32 maxReferralLifetime;
|
19
|
+
bool allowSelfReferrals;
|
20
|
+
bool allowRenewals;
|
21
|
+
bytes data;
|
22
|
+
}
|
23
|
+
|
24
|
+
struct DistributorInfo {
|
25
|
+
DistributorType distributorType;
|
26
|
+
bool active;
|
27
|
+
bytes data;
|
28
|
+
Amount commissionAmount;
|
29
|
+
uint32 numPoliciesSold;
|
30
|
+
}
|
31
|
+
|
32
|
+
struct ReferralInfo {
|
33
|
+
NftId distributorNftId;
|
34
|
+
string referralCode;
|
35
|
+
UFixed discountPercentage;
|
36
|
+
uint32 maxReferrals;
|
37
|
+
uint32 usedReferrals;
|
38
|
+
Timestamp expiryAt;
|
39
|
+
bytes data;
|
40
|
+
}
|
41
|
+
|
42
|
+
}
|
@@ -0,0 +1,78 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount} from "../../type/Amount.sol";
|
5
|
+
import {NftId} from "../../type/NftId.sol";
|
6
|
+
import {ClaimId} from "../../type/ClaimId.sol";
|
7
|
+
import {ReferralId} from "../../type/Referral.sol";
|
8
|
+
import {RiskId} from "../../type/RiskId.sol";
|
9
|
+
import {Seconds} from "../../type/Seconds.sol";
|
10
|
+
import {Timestamp} from "../../type/Timestamp.sol";
|
11
|
+
|
12
|
+
interface IPolicy {
|
13
|
+
|
14
|
+
struct Premium {
|
15
|
+
// this is the net premium calculated by the product
|
16
|
+
uint256 netPremiumAmount;
|
17
|
+
// fullPremium = netPremium + all fixed amounts + all variable amounts (excl commission and minDistribtuionOwnerFee variable part)
|
18
|
+
uint256 fullPremiumAmount;
|
19
|
+
// premium = fullPremium - discount
|
20
|
+
uint256 premiumAmount;
|
21
|
+
uint256 productFeeFixAmount;
|
22
|
+
uint256 poolFeeFixAmount;
|
23
|
+
uint256 bundleFeeFixAmount;
|
24
|
+
uint256 distributionFeeFixAmount;
|
25
|
+
uint256 productFeeVarAmount;
|
26
|
+
uint256 poolFeeVarAmount;
|
27
|
+
uint256 bundleFeeVarAmount;
|
28
|
+
uint256 distributionFeeVarAmount;
|
29
|
+
uint256 distributionOwnerFeeFixAmount;
|
30
|
+
// this is the remaining amount when the commission and discount are subtracted from the distribution fee variable part (must be at least the minDistributionOwnerFee)
|
31
|
+
uint256 distributionOwnerFeeVarAmount;
|
32
|
+
// this value is based on distributor type referenced in the referral
|
33
|
+
uint256 commissionAmount;
|
34
|
+
// this is based on referral used
|
35
|
+
uint256 discountAmount;
|
36
|
+
}
|
37
|
+
|
38
|
+
/// @dev policy data for the full policy lifecycle
|
39
|
+
struct PolicyInfo {
|
40
|
+
NftId productNftId;
|
41
|
+
NftId bundleNftId;
|
42
|
+
ReferralId referralId;
|
43
|
+
RiskId riskId;
|
44
|
+
Amount sumInsuredAmount;
|
45
|
+
Amount premiumAmount;
|
46
|
+
Amount premiumPaidAmount; // when lower than premium amount: max payout decreased accordingly
|
47
|
+
Seconds lifetime;
|
48
|
+
// policy application data, no changes after applying for a policy
|
49
|
+
bytes applicationData;
|
50
|
+
bytes processData;
|
51
|
+
uint16 claimsCount;
|
52
|
+
uint16 openClaimsCount;
|
53
|
+
Amount claimAmount; // sum of confirmed claim amounts (max = sum insured amount)
|
54
|
+
Amount payoutAmount; // sum of payouts (max = sum confirmed claim amountst)
|
55
|
+
Timestamp activatedAt; // time of underwriting
|
56
|
+
Timestamp expiredAt; // no new claims (activatedAt + lifetime)
|
57
|
+
Timestamp closedAt; // no locked capital (or declinedAt)
|
58
|
+
}
|
59
|
+
|
60
|
+
// claimId neeeds to be encoded policyNftId:claimId combination
|
61
|
+
struct ClaimInfo {
|
62
|
+
Amount claimAmount;
|
63
|
+
Amount paidAmount;
|
64
|
+
uint8 payoutsCount;
|
65
|
+
uint8 openPayoutsCount;
|
66
|
+
bytes submissionData; // claim submission data, no changes after submitting the claim
|
67
|
+
bytes processData; // data that may include information supporting confirm or decline
|
68
|
+
Timestamp closedAt; // payment of confirmed claim amount (or declinedAt)
|
69
|
+
}
|
70
|
+
|
71
|
+
// claimId neeeds to be encoded policyNftId:claimId combination
|
72
|
+
struct PayoutInfo {
|
73
|
+
ClaimId claimId;
|
74
|
+
Amount amount;
|
75
|
+
bytes data;
|
76
|
+
Timestamp paidAt; // payoment of confirmed claim amount (or declinedAt)
|
77
|
+
}
|
78
|
+
}
|