@etherisc/gif-next 0.0.2-8e5f0ee-617 → 0.0.2-8f3d499-425
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 +31 -3
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +33 -52
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +2 -2
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +0 -19
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +2 -2
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +2 -2
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +85 -248
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +16 -16
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +43 -222
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +228 -217
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +93 -101
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +43 -37
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +120 -31
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1463 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +410 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1960 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +414 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1411 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1171 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1517 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +1978 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +6 -6
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +5 -5
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +17 -106
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +98 -101
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +31 -31
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +238 -123
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +44 -151
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +61 -81
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +215 -219
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
- package/artifacts/contracts/instance/base/{ObjectManager.sol/ObjectManager.json → ObjectSet.sol/ObjectSet.json} +6 -6
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +59 -235
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +2 -2
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +30 -37
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +27 -219
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +37 -144
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +60 -80
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +55 -284
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +16 -16
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +407 -174
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +137 -89
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +205 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +45 -95
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +300 -180
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +45 -280
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +366 -329
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +74 -82
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +36 -162
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +57 -89
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +22 -225
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +16 -16
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +206 -175
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +92 -100
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +5 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +114 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +266 -119
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +43 -43
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +19 -37
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +2 -2
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +372 -316
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +104 -100
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +118 -265
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +80 -120
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +22 -225
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +588 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +682 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +257 -9
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +0 -183
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +476 -67
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +246 -134
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +23 -130
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +52 -72
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1169 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +6 -6
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +2 -2
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +0 -211
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +247 -161
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +105 -95
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +5 -112
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +92 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +0 -26
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +153 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +19 -37
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +14 -46
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +19 -222
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
- package/artifacts/contracts/shared/{NftIdSetManager.sol/NftIdSetManager.json → NftIdSet.sol/NftIdSet.json} +4 -4
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +6 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +18 -140
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +8 -97
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +5 -112
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +330 -11
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +108 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +27 -27
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +73 -93
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +85 -262
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +2 -2
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +77 -88
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +6 -6
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +31 -138
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +56 -76
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +92 -87
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +59 -23
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +61 -8
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +7 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +60 -4
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +50 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +9 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +39 -2
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +21 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +586 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +3 -3
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +25 -24
- package/contracts/authorization/Authorization.sol +0 -1
- package/contracts/authorization/IAccessAdmin.sol +0 -1
- package/contracts/distribution/BasicDistribution.sol +4 -15
- package/contracts/distribution/BasicDistributionAuthorization.sol +5 -1
- package/contracts/distribution/Distribution.sol +23 -11
- package/contracts/distribution/DistributionService.sol +75 -41
- package/contracts/distribution/DistributionServiceManager.sol +8 -11
- package/contracts/distribution/IDistributionComponent.sol +8 -4
- package/contracts/distribution/IDistributionService.sol +18 -2
- package/contracts/examples/fire/DamageLevel.sol +56 -0
- package/contracts/examples/fire/FirePool.sol +75 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
- package/contracts/examples/fire/FireProduct.sol +404 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +39 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +50 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +76 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +351 -0
- package/contracts/instance/{BundleManager.sol → BundleSet.sol} +23 -23
- package/contracts/instance/IInstance.sol +11 -34
- package/contracts/instance/IInstanceService.sol +5 -5
- package/contracts/instance/Instance.sol +13 -38
- package/contracts/instance/InstanceAdmin.sol +25 -6
- package/contracts/instance/InstanceAuthorizationV3.sol +16 -14
- package/contracts/instance/InstanceReader.sol +32 -7
- package/contracts/instance/InstanceService.sol +70 -47
- package/contracts/instance/InstanceServiceManager.sol +8 -13
- package/contracts/instance/InstanceStore.sol +12 -1
- package/contracts/instance/base/ObjectLifecycle.sol +9 -4
- package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +5 -5
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +1 -7
- package/contracts/instance/module/IDistribution.sol +0 -1
- package/contracts/instance/module/IPolicy.sol +22 -22
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/IOracleComponent.sol +2 -1
- package/contracts/oracle/Oracle.sol +17 -7
- package/contracts/oracle/OracleService.sol +9 -6
- package/contracts/oracle/OracleServiceManager.sol +8 -11
- package/contracts/pool/BasicPool.sol +7 -5
- package/contracts/pool/BasicPoolAuthorization.sol +11 -2
- package/contracts/pool/BundleService.sol +197 -55
- package/contracts/pool/BundleServiceManager.sol +8 -11
- package/contracts/pool/IBundleService.sol +33 -5
- package/contracts/pool/IPoolComponent.sol +6 -0
- package/contracts/pool/IPoolService.sol +38 -28
- package/contracts/pool/Pool.sol +40 -25
- package/contracts/pool/PoolService.sol +183 -112
- package/contracts/pool/PoolServiceManager.sol +6 -9
- package/contracts/product/ApplicationService.sol +55 -62
- package/contracts/product/ApplicationServiceManager.sol +6 -6
- package/contracts/product/BasicProduct.sol +3 -32
- package/contracts/product/BasicProductAuthorization.sol +3 -0
- package/contracts/product/ClaimService.sol +217 -110
- package/contracts/product/ClaimServiceManager.sol +6 -6
- package/contracts/product/IApplicationService.sol +1 -0
- package/contracts/product/IClaimService.sol +28 -5
- package/contracts/product/IPolicyService.sol +31 -32
- package/contracts/product/IPricingService.sol +7 -7
- package/contracts/product/IProductComponent.sol +1 -1
- package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
- package/contracts/product/PolicyService.sol +370 -194
- package/contracts/product/PolicyServiceManager.sol +6 -9
- package/contracts/product/PricingService.sol +46 -46
- package/contracts/product/PricingServiceManager.sol +5 -8
- package/contracts/product/Product.sol +68 -35
- package/contracts/product/{ProductService.sol → RiskService.sol} +13 -41
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +65 -32
- package/contracts/registry/IRegistry.sol +63 -16
- package/contracts/registry/IRegistryService.sol +6 -6
- package/contracts/registry/Registry.sol +333 -209
- package/contracts/registry/RegistryAdmin.sol +171 -72
- package/contracts/registry/RegistryService.sol +6 -20
- package/contracts/registry/RegistryServiceManager.sol +4 -4
- package/contracts/registry/{ReleaseManager.sol → ReleaseRegistry.sol} +60 -56
- package/contracts/registry/ServiceAuthorizationV3.sol +8 -10
- package/contracts/registry/TokenRegistry.sol +2 -2
- package/contracts/shared/Component.sol +30 -43
- package/contracts/shared/ComponentService.sol +88 -28
- package/contracts/shared/ComponentServiceManager.sol +10 -7
- package/contracts/shared/ComponentVerifyingService.sol +1 -1
- package/contracts/shared/ContractLib.sol +38 -0
- package/contracts/shared/IComponent.sol +4 -4
- package/contracts/shared/IComponentService.sol +15 -9
- package/contracts/shared/IInstanceLinkedComponent.sol +9 -10
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IService.sol +1 -1
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +3 -3
- package/contracts/shared/InstanceLinkedComponent.sol +25 -4
- package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
- package/contracts/shared/NftOwnable.sol +7 -7
- package/contracts/shared/PolicyHolder.sol +14 -58
- package/contracts/shared/Registerable.sol +4 -4
- package/contracts/shared/RegistryLinked.sol +3 -2
- package/contracts/shared/Service.sol +19 -15
- package/contracts/shared/TokenHandler.sol +100 -19
- package/contracts/shared/TokenHandlerDeployerLib.sol +12 -0
- package/contracts/staking/IStaking.sol +3 -3
- package/contracts/staking/IStakingService.sol +12 -5
- package/contracts/staking/StakeManagerLib.sol +18 -25
- package/contracts/staking/Staking.sol +27 -42
- package/contracts/staking/StakingManager.sol +10 -12
- package/contracts/staking/StakingReader.sol +12 -16
- package/contracts/staking/StakingService.sol +10 -14
- package/contracts/staking/StakingServiceManager.sol +4 -4
- package/contracts/staking/StakingStore.sol +12 -22
- package/contracts/staking/TargetManagerLib.sol +7 -3
- package/contracts/type/Amount.sol +27 -5
- package/contracts/type/Blocknumber.sol +7 -1
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/NftId.sol +1 -0
- package/contracts/type/ObjectType.sol +18 -18
- package/contracts/type/Referral.sol +1 -0
- package/contracts/type/RiskId.sol +15 -1
- package/contracts/type/Seconds.sol +21 -1
- package/contracts/type/StateId.sol +1 -0
- package/contracts/type/Timestamp.sol +11 -1
- package/contracts/type/UFixed.sol +29 -10
- package/contracts/type/Version.sol +3 -1
- package/contracts/{shared → upgradeability}/ProxyManager.sol +70 -38
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
- package/package.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -703
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -708
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1159
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
- package/contracts/product/ProductServiceManager.sol +0 -42
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
@@ -0,0 +1,56 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
type DamageLevel is uint8;
|
5
|
+
|
6
|
+
// type bindings
|
7
|
+
using {
|
8
|
+
DamageLevelLib.eq,
|
9
|
+
DamageLevelLib.eqz,
|
10
|
+
DamageLevelLib.toInt
|
11
|
+
} for DamageLevel global;
|
12
|
+
|
13
|
+
function DAMAGE_SMALL() pure returns (DamageLevel) {
|
14
|
+
return DamageLevel.wrap(1);
|
15
|
+
}
|
16
|
+
|
17
|
+
function DAMAGE_MEDIUM() pure returns (DamageLevel) {
|
18
|
+
return DamageLevel.wrap(2);
|
19
|
+
}
|
20
|
+
|
21
|
+
function DAMAGE_HIGH() pure returns (DamageLevel) {
|
22
|
+
return DamageLevel.wrap(3);
|
23
|
+
}
|
24
|
+
|
25
|
+
library DamageLevelLib {
|
26
|
+
|
27
|
+
error ErrorDamageLeveLibInvalidDamageLevel(uint8 damageLevel);
|
28
|
+
|
29
|
+
function zero() internal pure returns (DamageLevel) {
|
30
|
+
return DamageLevel.wrap(0);
|
31
|
+
}
|
32
|
+
|
33
|
+
function toDamageLevel(uint8 damage) internal pure returns (DamageLevel) {
|
34
|
+
if (damage == 1) {
|
35
|
+
return DAMAGE_SMALL();
|
36
|
+
} else if (damage == 2) {
|
37
|
+
return DAMAGE_MEDIUM();
|
38
|
+
} else if (damage == 3) {
|
39
|
+
return DAMAGE_HIGH();
|
40
|
+
} else {
|
41
|
+
revert ErrorDamageLeveLibInvalidDamageLevel(damage);
|
42
|
+
}
|
43
|
+
}
|
44
|
+
|
45
|
+
function toInt(DamageLevel damageLevel) internal pure returns (uint8) {
|
46
|
+
return uint8(DamageLevel.unwrap(damageLevel));
|
47
|
+
}
|
48
|
+
|
49
|
+
function eq(DamageLevel a, DamageLevel b) internal pure returns (bool) {
|
50
|
+
return DamageLevel.unwrap(a) == DamageLevel.unwrap(b);
|
51
|
+
}
|
52
|
+
|
53
|
+
function eqz(DamageLevel a) internal pure returns (bool) {
|
54
|
+
return DamageLevel.unwrap(a) == 0;
|
55
|
+
}
|
56
|
+
}
|
@@ -0,0 +1,75 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {Amount, AmountLib} from "../../type/Amount.sol";
|
5
|
+
import {BasicPool} from "../../pool/BasicPool.sol";
|
6
|
+
import {BasicPoolAuthorization} from "../../pool/BasicPoolAuthorization.sol";
|
7
|
+
import {Fee} from "../../type/Fee.sol";
|
8
|
+
import {IAuthorization} from "../../authorization/IAuthorization.sol";
|
9
|
+
import {NftId} from "../../type/NftId.sol";
|
10
|
+
import {Seconds} from "../../type/Timestamp.sol";
|
11
|
+
import {UFixed} from "../../type/UFixed.sol";
|
12
|
+
|
13
|
+
contract FirePool is
|
14
|
+
BasicPool
|
15
|
+
{
|
16
|
+
|
17
|
+
constructor(
|
18
|
+
address registry,
|
19
|
+
NftId instanceNftId,
|
20
|
+
string memory componentName,
|
21
|
+
address token,
|
22
|
+
IAuthorization authorization
|
23
|
+
)
|
24
|
+
{
|
25
|
+
address initialOwner = msg.sender;
|
26
|
+
_intialize(
|
27
|
+
registry,
|
28
|
+
instanceNftId,
|
29
|
+
componentName,
|
30
|
+
token,
|
31
|
+
authorization,
|
32
|
+
initialOwner);
|
33
|
+
}
|
34
|
+
|
35
|
+
function _intialize(
|
36
|
+
address registry,
|
37
|
+
NftId instanceNftId,
|
38
|
+
string memory componentName,
|
39
|
+
address token,
|
40
|
+
IAuthorization authorization,
|
41
|
+
address initialOwner
|
42
|
+
)
|
43
|
+
internal
|
44
|
+
initializer
|
45
|
+
{
|
46
|
+
_initializeBasicPool(
|
47
|
+
registry,
|
48
|
+
instanceNftId,
|
49
|
+
authorization,
|
50
|
+
token,
|
51
|
+
componentName,
|
52
|
+
initialOwner);
|
53
|
+
}
|
54
|
+
|
55
|
+
function createBundle(
|
56
|
+
Fee memory fee,
|
57
|
+
Amount initialAmount,
|
58
|
+
Seconds lifetime
|
59
|
+
)
|
60
|
+
external
|
61
|
+
virtual
|
62
|
+
restricted()
|
63
|
+
returns(NftId bundleNftId, Amount netStakedAmount)
|
64
|
+
{
|
65
|
+
address owner = msg.sender;
|
66
|
+
bundleNftId = _createBundle(
|
67
|
+
owner,
|
68
|
+
fee,
|
69
|
+
lifetime,
|
70
|
+
"" // filter
|
71
|
+
);
|
72
|
+
netStakedAmount = _stake(bundleNftId, initialAmount);
|
73
|
+
}
|
74
|
+
|
75
|
+
}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
4
|
+
pragma solidity ^0.8.20;
|
5
|
+
|
6
|
+
import {BasicPoolAuthorization} from "../../pool/BasicPoolAuthorization.sol";
|
7
|
+
import {FirePool} from "./FirePool.sol";
|
8
|
+
import {IAccess} from "../../../contracts/authorization/IAccess.sol";
|
9
|
+
import {PUBLIC_ROLE} from "../../../contracts/type/RoleId.sol";
|
10
|
+
|
11
|
+
contract FirePoolAuthorization
|
12
|
+
is BasicPoolAuthorization
|
13
|
+
{
|
14
|
+
|
15
|
+
constructor(string memory poolName)
|
16
|
+
BasicPoolAuthorization(poolName)
|
17
|
+
{}
|
18
|
+
|
19
|
+
|
20
|
+
function _setupTargetAuthorizations()
|
21
|
+
internal
|
22
|
+
virtual override
|
23
|
+
{
|
24
|
+
super._setupTargetAuthorizations();
|
25
|
+
IAccess.FunctionInfo[] storage functions;
|
26
|
+
|
27
|
+
// authorize public role (open access to any account, only allows to lock target)
|
28
|
+
functions = _authorizeForTarget(getTargetName(), PUBLIC_ROLE());
|
29
|
+
// TODO: FirePool.createBundle must require a custom role (e.g. INVESTOR) instead of PUBLIC_ROLE
|
30
|
+
_authorize(functions, FirePool.createBundle.selector, "createBundle");
|
31
|
+
}
|
32
|
+
|
33
|
+
}
|
34
|
+
|
@@ -0,0 +1,404 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ACTIVE, COLLATERALIZED, PAUSED} from "../../type/StateId.sol";
|
5
|
+
import {Amount, AmountLib} from "../../type/Amount.sol";
|
6
|
+
import {BasicProduct} from "../../product/BasicProduct.sol";
|
7
|
+
import {ClaimId} from "../../type/ClaimId.sol";
|
8
|
+
import {DamageLevel, DamageLevelLib, DAMAGE_SMALL, DAMAGE_MEDIUM, DAMAGE_HIGH} from "./DamageLevel.sol";
|
9
|
+
import {IAuthorization} from "../../authorization/IAuthorization.sol";
|
10
|
+
import {IPolicy} from "../../instance/module/IPolicy.sol";
|
11
|
+
import {NftId} from "../../type/NftId.sol";
|
12
|
+
import {PayoutId} from "../../type/PayoutId.sol";
|
13
|
+
import {ReferralLib} from "../../type/Referral.sol";
|
14
|
+
import {RiskId, RiskIdLib} from "../../type/RiskId.sol";
|
15
|
+
import {Seconds} from "../../type/Seconds.sol";
|
16
|
+
import {StateId} from "../../type/StateId.sol";
|
17
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
18
|
+
import {UFixed, UFixedLib} from "../../type/UFixed.sol";
|
19
|
+
|
20
|
+
uint64 constant SPECIAL_ROLE_INT = 11111;
|
21
|
+
|
22
|
+
function HALF_YEAR() pure returns (Seconds) {
|
23
|
+
return Seconds.wrap(180 * 86400);
|
24
|
+
}
|
25
|
+
|
26
|
+
function ONE_YEAR() pure returns (Seconds) {
|
27
|
+
return Seconds.wrap(360 * 86400);
|
28
|
+
}
|
29
|
+
|
30
|
+
/// @dev This is the product component for the fire insurance example.
|
31
|
+
/// It show how to insure a house for a given suminsured in a city.
|
32
|
+
/// The risk is based on the city.
|
33
|
+
/// If a fire is reported in the city, the policy holder is able to submit a claim and get a payout.
|
34
|
+
contract FireProduct is
|
35
|
+
BasicProduct
|
36
|
+
{
|
37
|
+
struct Fire {
|
38
|
+
string cityName;
|
39
|
+
DamageLevel damageLevel;
|
40
|
+
Timestamp reportedAt;
|
41
|
+
}
|
42
|
+
|
43
|
+
error ErrorFireProductCityUnknown(string cityName);
|
44
|
+
error ErrorFireProductTimestampTooEarly();
|
45
|
+
error ErrorFireProductFireAlreadyReported();
|
46
|
+
error ErrorFireProductAlreadyClaimed();
|
47
|
+
error ErrorFireProductPolicyNotActive();
|
48
|
+
error ErrorFireProductPolicyNotYetActive(Timestamp activateAt);
|
49
|
+
error ErrorFireProductPolicyExpired(Timestamp expiredAt);
|
50
|
+
error ErrorFireProductUnknownDamageLevel(DamageLevel damageLevel);
|
51
|
+
error ErrorFireProductFireUnknown(uint256 fireId);
|
52
|
+
error ErrorFireProductNotPolicyOwner(NftId nftId, address owner);
|
53
|
+
|
54
|
+
string[] private _cities;
|
55
|
+
// map from city name to the RiskId
|
56
|
+
mapping(string cityName => RiskId risk) private _riskMapping;
|
57
|
+
|
58
|
+
// // map from city name to the damage level and the time of the report
|
59
|
+
mapping(uint256 fireId => Fire) private _fires;
|
60
|
+
mapping(uint256 fireId => mapping (NftId policyId => bool claimed)) private _claimed;
|
61
|
+
|
62
|
+
constructor(
|
63
|
+
address registry,
|
64
|
+
NftId instanceNftid,
|
65
|
+
string memory componentName,
|
66
|
+
address token,
|
67
|
+
address pool,
|
68
|
+
IAuthorization authorization
|
69
|
+
)
|
70
|
+
{
|
71
|
+
address initialOwner = msg.sender;
|
72
|
+
_initialize(
|
73
|
+
registry,
|
74
|
+
instanceNftid,
|
75
|
+
componentName,
|
76
|
+
token,
|
77
|
+
pool,
|
78
|
+
authorization,
|
79
|
+
initialOwner);
|
80
|
+
}
|
81
|
+
|
82
|
+
function _initialize(
|
83
|
+
address registry,
|
84
|
+
NftId instanceNftid,
|
85
|
+
string memory componentName,
|
86
|
+
address token,
|
87
|
+
address pool,
|
88
|
+
IAuthorization authorization,
|
89
|
+
address initialOwner
|
90
|
+
)
|
91
|
+
internal
|
92
|
+
initializer
|
93
|
+
{
|
94
|
+
_initializeBasicProduct(
|
95
|
+
registry,
|
96
|
+
instanceNftid,
|
97
|
+
authorization,
|
98
|
+
initialOwner,
|
99
|
+
componentName,
|
100
|
+
token,
|
101
|
+
false,
|
102
|
+
pool,
|
103
|
+
address(0)); // no distribution
|
104
|
+
}
|
105
|
+
|
106
|
+
function cities() public view returns (uint256) {
|
107
|
+
return _cities.length;
|
108
|
+
}
|
109
|
+
|
110
|
+
function city(uint256 idx) public view returns (string memory) {
|
111
|
+
return _cities[idx];
|
112
|
+
}
|
113
|
+
|
114
|
+
function riskId(string memory cityName) public view returns (RiskId) {
|
115
|
+
return _riskMapping[cityName];
|
116
|
+
}
|
117
|
+
|
118
|
+
function pauseCity(
|
119
|
+
string memory cityName
|
120
|
+
)
|
121
|
+
public
|
122
|
+
restricted()
|
123
|
+
{
|
124
|
+
if (_riskMapping[cityName].eqz()) {
|
125
|
+
revert ErrorFireProductCityUnknown(cityName);
|
126
|
+
}
|
127
|
+
|
128
|
+
_updateRiskState(
|
129
|
+
_riskMapping[cityName],
|
130
|
+
PAUSED()
|
131
|
+
);
|
132
|
+
}
|
133
|
+
|
134
|
+
function unpauseCity(
|
135
|
+
string memory cityName
|
136
|
+
)
|
137
|
+
public
|
138
|
+
restricted()
|
139
|
+
{
|
140
|
+
if (_riskMapping[cityName].eqz()) {
|
141
|
+
revert ErrorFireProductCityUnknown(cityName);
|
142
|
+
}
|
143
|
+
|
144
|
+
_updateRiskState(
|
145
|
+
_riskMapping[cityName],
|
146
|
+
ACTIVE()
|
147
|
+
);
|
148
|
+
}
|
149
|
+
|
150
|
+
function calculatePremium(
|
151
|
+
string memory cityName,
|
152
|
+
Amount sumInsured,
|
153
|
+
Seconds lifetime,
|
154
|
+
NftId bundleNftId
|
155
|
+
)
|
156
|
+
public
|
157
|
+
view
|
158
|
+
returns (Amount premiumAmount)
|
159
|
+
{
|
160
|
+
RiskId riskId = _riskMapping[cityName];
|
161
|
+
if (riskId.eqz()) {
|
162
|
+
revert ErrorFireProductCityUnknown(cityName);
|
163
|
+
}
|
164
|
+
premiumAmount = calculatePremium(
|
165
|
+
sumInsured,
|
166
|
+
riskId,
|
167
|
+
lifetime,
|
168
|
+
"",
|
169
|
+
bundleNftId,
|
170
|
+
ReferralLib.zero());
|
171
|
+
}
|
172
|
+
|
173
|
+
function calculateNetPremium(
|
174
|
+
Amount sumInsured,
|
175
|
+
RiskId,
|
176
|
+
Seconds lifetime,
|
177
|
+
bytes memory
|
178
|
+
)
|
179
|
+
external
|
180
|
+
view
|
181
|
+
virtual override
|
182
|
+
returns (Amount netPremiumAmount)
|
183
|
+
{
|
184
|
+
UFixed numDays = UFixedLib.toUFixed(lifetime.toInt() / 86400);
|
185
|
+
// to simplify time calculation we assume 360 days per year
|
186
|
+
UFixed pctOfYear = numDays / UFixedLib.toUFixed(360);
|
187
|
+
Amount premiumPerYear = AmountLib.toAmount(sumInsured.toInt() / 20);
|
188
|
+
return premiumPerYear.multiplyWith(pctOfYear);
|
189
|
+
}
|
190
|
+
|
191
|
+
function createApplication(
|
192
|
+
string memory cityName,
|
193
|
+
Amount sumInsured,
|
194
|
+
Seconds lifetime,
|
195
|
+
NftId bundleNftId
|
196
|
+
)
|
197
|
+
public
|
198
|
+
restricted()
|
199
|
+
returns (NftId policyNftId)
|
200
|
+
{
|
201
|
+
address applicationOwner = msg.sender;
|
202
|
+
RiskId riskId = initializeCity(cityName);
|
203
|
+
|
204
|
+
Amount premiumAmount = calculatePremium(
|
205
|
+
sumInsured,
|
206
|
+
riskId,
|
207
|
+
lifetime,
|
208
|
+
"",
|
209
|
+
bundleNftId,
|
210
|
+
ReferralLib.zero());
|
211
|
+
|
212
|
+
return _createApplication(
|
213
|
+
applicationOwner,
|
214
|
+
riskId,
|
215
|
+
sumInsured,
|
216
|
+
premiumAmount,
|
217
|
+
lifetime,
|
218
|
+
bundleNftId,
|
219
|
+
ReferralLib.zero(),
|
220
|
+
""
|
221
|
+
);
|
222
|
+
}
|
223
|
+
|
224
|
+
function initializeCity(
|
225
|
+
string memory cityName
|
226
|
+
)
|
227
|
+
public
|
228
|
+
returns (RiskId riskId)
|
229
|
+
{
|
230
|
+
if (! _riskMapping[cityName].eqz()) {
|
231
|
+
return _riskMapping[cityName];
|
232
|
+
}
|
233
|
+
_cities.push(cityName);
|
234
|
+
riskId = RiskIdLib.toRiskId(cityName);
|
235
|
+
_createRisk(riskId, "");
|
236
|
+
_riskMapping[cityName] = riskId;
|
237
|
+
}
|
238
|
+
|
239
|
+
/// @dev Calling this method will lock the sum insured amount in the pool and activate the policy at the given time.
|
240
|
+
/// It will also collect the tokens payment for the premium. An approval with the correct amount towards the TokenHandler of the product is therefor required.
|
241
|
+
function createPolicy(
|
242
|
+
NftId policyNftId,
|
243
|
+
Timestamp activateAt
|
244
|
+
)
|
245
|
+
public
|
246
|
+
restricted()
|
247
|
+
{
|
248
|
+
_createPolicy(policyNftId, activateAt);
|
249
|
+
_collectPremium(policyNftId, activateAt);
|
250
|
+
}
|
251
|
+
|
252
|
+
/// @dev Decline the policy application
|
253
|
+
function decline(
|
254
|
+
NftId policyNftId
|
255
|
+
)
|
256
|
+
public
|
257
|
+
restricted()
|
258
|
+
{
|
259
|
+
_decline(policyNftId);
|
260
|
+
}
|
261
|
+
|
262
|
+
function expire(
|
263
|
+
NftId policyNftId,
|
264
|
+
Timestamp expireAt
|
265
|
+
)
|
266
|
+
public
|
267
|
+
restricted()
|
268
|
+
returns (Timestamp)
|
269
|
+
{
|
270
|
+
return _expire(policyNftId, expireAt);
|
271
|
+
}
|
272
|
+
|
273
|
+
function close(
|
274
|
+
NftId policyNftId
|
275
|
+
)
|
276
|
+
public
|
277
|
+
restricted()
|
278
|
+
{
|
279
|
+
_close(policyNftId);
|
280
|
+
}
|
281
|
+
|
282
|
+
function reportFire(
|
283
|
+
uint256 fireId,
|
284
|
+
string memory cityName,
|
285
|
+
DamageLevel damageLevel,
|
286
|
+
Timestamp reportedAt
|
287
|
+
)
|
288
|
+
public
|
289
|
+
restricted()
|
290
|
+
{
|
291
|
+
if (_riskMapping[cityName].eqz()) {
|
292
|
+
revert ErrorFireProductCityUnknown(cityName);
|
293
|
+
}
|
294
|
+
|
295
|
+
if (reportedAt < TimestampLib.blockTimestamp()) {
|
296
|
+
revert ErrorFireProductTimestampTooEarly();
|
297
|
+
}
|
298
|
+
|
299
|
+
if (! _fires[fireId].reportedAt.eqz()) {
|
300
|
+
revert ErrorFireProductFireAlreadyReported();
|
301
|
+
}
|
302
|
+
|
303
|
+
_fires[fireId] = Fire({
|
304
|
+
cityName: cityName,
|
305
|
+
damageLevel: damageLevel,
|
306
|
+
reportedAt: reportedAt
|
307
|
+
});
|
308
|
+
}
|
309
|
+
|
310
|
+
function fire(uint256 fireId) public view returns (Fire memory) {
|
311
|
+
return _fires[fireId];
|
312
|
+
}
|
313
|
+
|
314
|
+
function submitClaim(
|
315
|
+
NftId policyNftId,
|
316
|
+
uint256 fireId
|
317
|
+
)
|
318
|
+
public
|
319
|
+
restricted()
|
320
|
+
onlyNftOwner(policyNftId)
|
321
|
+
returns (ClaimId claimId, PayoutId payoutId)
|
322
|
+
{
|
323
|
+
IPolicy.PolicyInfo memory policyInfo = _getInstanceReader().getPolicyInfo(policyNftId);
|
324
|
+
_checkClaimConditions(policyNftId, fireId, policyInfo);
|
325
|
+
|
326
|
+
Fire memory fire = _fires[fireId];
|
327
|
+
_claimed[fireId][policyNftId] = true;
|
328
|
+
|
329
|
+
Amount claimAmount = _getClaimAmount(policyInfo, fire);
|
330
|
+
Amount maxPayoutRemaining = policyInfo.sumInsuredAmount - policyInfo.payoutAmount;
|
331
|
+
|
332
|
+
// if payout is higher than the remaining maximum payout, then claim what is remaining
|
333
|
+
// TODO: leave claim amount as is and only confirm/payout reduced amount
|
334
|
+
if (maxPayoutRemaining < claimAmount) {
|
335
|
+
claimAmount = maxPayoutRemaining;
|
336
|
+
}
|
337
|
+
|
338
|
+
claimId = _submitClaim(policyNftId, claimAmount, "");
|
339
|
+
_confirmClaim(policyNftId, claimId, claimAmount, "");
|
340
|
+
|
341
|
+
payoutId = _createPayout(policyNftId, claimId, claimAmount, "");
|
342
|
+
_processPayout(policyNftId, payoutId);
|
343
|
+
|
344
|
+
policyInfo = _getInstanceReader().getPolicyInfo(policyNftId);
|
345
|
+
|
346
|
+
if (policyInfo.payoutAmount >= policyInfo.sumInsuredAmount) {
|
347
|
+
close(policyNftId);
|
348
|
+
}
|
349
|
+
}
|
350
|
+
|
351
|
+
function _checkClaimConditions(
|
352
|
+
NftId policyNftId,
|
353
|
+
uint256 fireId,
|
354
|
+
IPolicy.PolicyInfo memory policyInfo
|
355
|
+
)
|
356
|
+
internal
|
357
|
+
{
|
358
|
+
// check fire exists
|
359
|
+
if (_fires[fireId].reportedAt.eqz()) {
|
360
|
+
revert ErrorFireProductFireUnknown(fireId);
|
361
|
+
}
|
362
|
+
|
363
|
+
// check policy has not been claimed yet for this fire
|
364
|
+
if (_claimed[fireId][policyNftId]) {
|
365
|
+
revert ErrorFireProductAlreadyClaimed();
|
366
|
+
}
|
367
|
+
|
368
|
+
StateId policyState = _getInstanceReader().getPolicyState(policyNftId);
|
369
|
+
|
370
|
+
if (! policyState.eq(COLLATERALIZED())) {
|
371
|
+
revert ErrorFireProductPolicyNotActive();
|
372
|
+
}
|
373
|
+
|
374
|
+
Fire memory fire = _fires[fireId];
|
375
|
+
|
376
|
+
if (fire.reportedAt < policyInfo.activatedAt) {
|
377
|
+
revert ErrorFireProductPolicyNotYetActive(policyInfo.activatedAt);
|
378
|
+
}
|
379
|
+
|
380
|
+
if (fire.reportedAt > policyInfo.expiredAt) {
|
381
|
+
revert ErrorFireProductPolicyExpired(policyInfo.expiredAt);
|
382
|
+
}
|
383
|
+
}
|
384
|
+
|
385
|
+
function _getClaimAmount(
|
386
|
+
IPolicy.PolicyInfo memory policyInfo,
|
387
|
+
Fire memory fire
|
388
|
+
)
|
389
|
+
internal
|
390
|
+
view
|
391
|
+
returns (Amount)
|
392
|
+
{
|
393
|
+
if (fire.damageLevel.eq(DAMAGE_SMALL())) {
|
394
|
+
return policyInfo.sumInsuredAmount.multiplyWith(UFixedLib.toUFixed(25, -2));
|
395
|
+
} else if (fire.damageLevel.eq(DAMAGE_MEDIUM())) {
|
396
|
+
return policyInfo.sumInsuredAmount.multiplyWith(UFixedLib.toUFixed(5, -2));
|
397
|
+
} else if (fire.damageLevel.eq(DAMAGE_HIGH())) {
|
398
|
+
return policyInfo.sumInsuredAmount;
|
399
|
+
} else {
|
400
|
+
revert ErrorFireProductUnknownDamageLevel(fire.damageLevel);
|
401
|
+
}
|
402
|
+
}
|
403
|
+
|
404
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {BasicProductAuthorization} from "../../product/BasicProductAuthorization.sol";
|
5
|
+
import {FireProduct} from "./FireProduct.sol";
|
6
|
+
import {IAccess} from "../../../contracts/authorization/IAccess.sol";
|
7
|
+
import {PRODUCT_OWNER_ROLE, PUBLIC_ROLE} from "../../../contracts/type/RoleId.sol";
|
8
|
+
|
9
|
+
|
10
|
+
contract FireProductAuthorization
|
11
|
+
is BasicProductAuthorization
|
12
|
+
{
|
13
|
+
|
14
|
+
constructor(string memory poolName)
|
15
|
+
BasicProductAuthorization(poolName)
|
16
|
+
{}
|
17
|
+
|
18
|
+
function _setupTargetAuthorizations()
|
19
|
+
internal
|
20
|
+
virtual override
|
21
|
+
{
|
22
|
+
super._setupTargetAuthorizations();
|
23
|
+
IAccess.FunctionInfo[] storage functions;
|
24
|
+
|
25
|
+
// authorize public role (open access to any account, only allows to lock target)
|
26
|
+
functions = _authorizeForTarget(getTargetName(), PUBLIC_ROLE());
|
27
|
+
_authorize(functions, FireProduct.createApplication.selector, "createApplication");
|
28
|
+
_authorize(functions, FireProduct.submitClaim.selector, "submitClaim");
|
29
|
+
|
30
|
+
functions = _authorizeForTarget(getTargetName(), PRODUCT_OWNER_ROLE());
|
31
|
+
_authorize(functions, FireProduct.createPolicy.selector, "createPolicy");
|
32
|
+
_authorize(functions, FireProduct.decline.selector, "decline");
|
33
|
+
_authorize(functions, FireProduct.expire.selector, "expire");
|
34
|
+
_authorize(functions, FireProduct.close.selector, "close");
|
35
|
+
_authorize(functions, FireProduct.reportFire.selector, "reportFire");
|
36
|
+
}
|
37
|
+
|
38
|
+
}
|
39
|
+
|
@@ -0,0 +1,26 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {ERC20} from "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
5
|
+
|
6
|
+
/// @dev FireUSD is a stablecoin with 6 decimals and an initial supply of 1 Billion tokens.
|
7
|
+
contract FireUSD is ERC20 {
|
8
|
+
|
9
|
+
string public constant NAME = "FireUSD";
|
10
|
+
string public constant SYMBOL = "HOT";
|
11
|
+
uint8 public constant DECIMALS = 6;
|
12
|
+
uint256 public constant INITIAL_SUPPLY = 10**12 * 10**DECIMALS; // 1'000'000'000'000
|
13
|
+
|
14
|
+
constructor()
|
15
|
+
ERC20(NAME, SYMBOL)
|
16
|
+
{
|
17
|
+
_mint(
|
18
|
+
_msgSender(),
|
19
|
+
INITIAL_SUPPLY
|
20
|
+
);
|
21
|
+
}
|
22
|
+
|
23
|
+
function decimals() public pure override returns(uint8) {
|
24
|
+
return DECIMALS;
|
25
|
+
}
|
26
|
+
}
|
@@ -0,0 +1,50 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {BasicDistribution} from "../../distribution/BasicDistribution.sol";
|
5
|
+
import {IAuthorization} from "../../authorization/IAuthorization.sol";
|
6
|
+
import {NftId} from "../../type/NftId.sol";
|
7
|
+
|
8
|
+
|
9
|
+
contract SimpleDistribution is
|
10
|
+
BasicDistribution
|
11
|
+
{
|
12
|
+
|
13
|
+
constructor(
|
14
|
+
address registry,
|
15
|
+
NftId instanceNftId,
|
16
|
+
IAuthorization authorization,
|
17
|
+
address initialOwner,
|
18
|
+
address token
|
19
|
+
)
|
20
|
+
{
|
21
|
+
initialize(
|
22
|
+
registry,
|
23
|
+
instanceNftId,
|
24
|
+
authorization,
|
25
|
+
initialOwner,
|
26
|
+
"SimpleDistribution",
|
27
|
+
token);
|
28
|
+
}
|
29
|
+
|
30
|
+
function initialize(
|
31
|
+
address registry,
|
32
|
+
NftId instanceNftId,
|
33
|
+
IAuthorization authorization,
|
34
|
+
address initialOwner,
|
35
|
+
string memory name,
|
36
|
+
address token
|
37
|
+
)
|
38
|
+
public
|
39
|
+
virtual
|
40
|
+
initializer()
|
41
|
+
{
|
42
|
+
_initializeBasicDistribution(
|
43
|
+
registry,
|
44
|
+
instanceNftId,
|
45
|
+
authorization,
|
46
|
+
initialOwner,
|
47
|
+
name,
|
48
|
+
token);
|
49
|
+
}
|
50
|
+
}
|