@etherisc/gif-next 3.0.0-83fcfa1-162 → 3.0.0-88d56e0-185
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/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +42 -56
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +44 -48
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +14 -20
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +99 -87
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +2 -2
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +42 -29
- 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 +75 -63
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- 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 +20 -114
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +2 -2
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +2 -96
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +187 -114
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +75 -75
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +2 -96
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +113 -40
- package/artifacts/contracts/examples/crop/AccountingToken.sol/AccountingToken.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/AccountingToken.sol/AccountingToken.json +376 -0
- package/artifacts/contracts/examples/crop/CropPool.sol/CropPool.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/CropPool.sol/CropPool.json +1391 -0
- package/artifacts/contracts/examples/crop/CropPoolAuthorization.sol/CropPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/CropPoolAuthorization.sol/CropPoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/crop/CropProduct.sol/CropProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/CropProduct.sol/CropProduct.json +2433 -0
- package/artifacts/contracts/examples/crop/CropProductAuthorization.sol/CropProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/CropProductAuthorization.sol/CropProductAuthorization.json +891 -0
- package/artifacts/contracts/examples/crop/Location.sol/LocationLib.dbg.json +4 -0
- package/artifacts/contracts/examples/crop/Location.sol/LocationLib.json +199 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +2 -2
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +21 -96
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +2 -2
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +79 -159
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +2 -2
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +2 -2
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +41 -101
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +2 -2
- package/artifacts/contracts/examples/flight/FlightNft.sol/FlightNft.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightNft.sol/FlightNft.json +7 -7
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +61 -181
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +20 -20
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +23 -98
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +2 -2
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +100 -159
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +20 -20
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.json +22 -22
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +2 -2
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +2 -2
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +28 -122
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +2 -2
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +91 -83
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +29 -104
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +2 -2
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +42 -122
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +2 -2
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.json +50 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +59 -72
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +50 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +34 -21
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +108 -9
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +51 -33
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +191 -179
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +21 -21
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +127 -44
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +151 -36
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +41 -41
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +171 -121
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +166 -107
- package/artifacts/contracts/instance/RequestSet.sol/RequestSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RequestSet.sol/RequestSet.json +466 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +92 -105
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +9 -9
- 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 +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +3 -3
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +40 -4
- 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 +85 -77
- 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 +67 -59
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +19 -13
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +71 -63
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +57 -51
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +50 -50
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +4 -79
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +2 -2
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +90 -85
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +62 -62
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +32 -27
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +4 -79
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +56 -44
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +4 -79
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +4 -9
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +124 -112
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +63 -63
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +44 -44
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +44 -44
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +4 -79
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +2 -2
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +86 -80
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +67 -67
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +18 -18
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +24 -18
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +21 -9
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +4 -4
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +4 -79
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +27 -45
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +81 -69
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +7 -7
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +60 -60
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +42 -42
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +51 -51
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +4 -79
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +53 -87
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +41 -49
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +58 -8
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +30 -24
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +2 -2
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +1 -1
- 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 +132 -66
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +168 -156
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +2 -27
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +8 -8
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +37 -37
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +198 -186
- 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 +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +119 -110
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +19 -19
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +20 -20
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +2 -77
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +314 -123
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +61 -61
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +2 -2
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.json +2 -77
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +2 -77
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +256 -65
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +2 -77
- 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/INftOwnable.sol/INftOwnable.json +2 -2
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +2 -2
- 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/IService.sol/IService.json +2 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -2
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +2 -77
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +4 -4
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +2 -2
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +2 -2
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +39 -66
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +22 -49
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +28 -28
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +69 -150
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +15 -221
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +117 -198
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +2 -7
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +53 -53
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +2 -2
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +35 -241
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +40 -40
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +220 -220
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +9 -14
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +2 -7
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +2 -7
- 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/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- 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 +2 -7
- 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/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.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 +23 -4
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +17 -22
- 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 +2 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +2 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- 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/String.sol/StrLib.json +2 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +2 -7
- 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 +2 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +22 -22
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +3 -3
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/accounting/AccountingService.sol +17 -29
- package/contracts/accounting/IAccountingService.sol +7 -8
- package/contracts/authorization/AccessAdmin.sol +10 -8
- package/contracts/authorization/AccessManagerCloneable.sol +4 -0
- package/contracts/authorization/IAccessAdmin.sol +9 -8
- package/contracts/distribution/DistributionService.sol +24 -19
- package/contracts/distribution/IDistributionComponent.sol +0 -2
- package/contracts/distribution/IDistributionService.sol +8 -7
- package/contracts/examples/crop/AccountingToken.sol +26 -0
- package/contracts/examples/crop/CropPool.sol +89 -0
- package/contracts/examples/crop/CropPoolAuthorization.sol +37 -0
- package/contracts/examples/crop/CropProduct.sol +512 -0
- package/contracts/examples/crop/CropProductAuthorization.sol +69 -0
- package/contracts/examples/crop/Location.sol +50 -0
- package/contracts/examples/fire/FireProduct.sol +1 -1
- package/contracts/examples/flight/FlightLib.sol +11 -39
- package/contracts/examples/flight/FlightOracle.sol +1 -98
- package/contracts/examples/flight/FlightOracleAuthorization.sol +2 -3
- package/contracts/examples/flight/FlightProduct.sol +11 -8
- package/contracts/examples/flight/FlightProductAuthorization.sol +1 -1
- package/contracts/examples/unpermissioned/SimpleProduct.sol +1 -5
- package/contracts/instance/BaseStore.sol +4 -0
- package/contracts/instance/BundleSet.sol +7 -8
- package/contracts/instance/IBaseStore.sol +8 -0
- package/contracts/instance/IInstance.sol +10 -7
- package/contracts/instance/IInstanceService.sol +11 -4
- package/contracts/instance/Instance.sol +8 -0
- package/contracts/instance/InstanceAdmin.sol +2 -1
- package/contracts/instance/InstanceAuthorizationV3.sol +15 -1
- package/contracts/instance/InstanceReader.sol +39 -4
- package/contracts/instance/InstanceService.sol +68 -36
- package/contracts/instance/InstanceStore.sol +14 -14
- package/contracts/instance/ProductStore.sol +16 -15
- package/contracts/instance/RequestSet.sol +63 -0
- package/contracts/instance/RiskSet.sol +6 -7
- package/contracts/instance/TargetNames.sol +1 -0
- package/contracts/instance/base/BalanceStore.sol +7 -7
- package/contracts/instance/base/ObjectCounter.sol +7 -5
- package/contracts/instance/base/ObjectSet.sol +9 -1
- package/contracts/instance/base/ObjectSetHelperLib.sol +5 -1
- package/contracts/oracle/IOracleComponent.sol +10 -0
- package/contracts/oracle/IOracleService.sol +5 -5
- package/contracts/oracle/Oracle.sol +49 -25
- package/contracts/oracle/OracleService.sol +26 -23
- package/contracts/pool/BundleService.sol +3 -3
- package/contracts/pool/IBundleService.sol +9 -10
- package/contracts/pool/IPoolComponent.sol +1 -1
- package/contracts/pool/IPoolService.sol +14 -14
- package/contracts/pool/PoolService.sol +2 -2
- package/contracts/product/ClaimService.sol +1 -1
- package/contracts/product/IApplicationService.sol +8 -8
- package/contracts/product/IClaimService.sol +9 -9
- package/contracts/product/IPolicyService.sol +7 -7
- package/contracts/product/IRiskService.sol +4 -6
- package/contracts/product/PolicyService.sol +1 -1
- package/contracts/product/Product.sol +1 -5
- package/contracts/product/RiskService.sol +3 -8
- package/contracts/registry/ChainNft.sol +9 -8
- package/contracts/registry/IRegistry.sol +11 -10
- package/contracts/registry/Registry.sol +16 -13
- package/contracts/registry/RegistryAuthorization.sol +0 -2
- package/contracts/registry/ReleaseAdmin.sol +4 -4
- package/contracts/registry/ReleaseRegistry.sol +7 -8
- package/contracts/registry/TokenRegistry.sol +3 -3
- package/contracts/shared/ComponentService.sol +33 -4
- package/contracts/shared/IComponent.sol +0 -4
- package/contracts/shared/IComponentService.sol +31 -10
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/InstanceLinkedComponent.sol +1 -1
- package/contracts/shared/TokenHandler.sol +5 -5
- package/contracts/staking/IStaking.sol +32 -32
- package/contracts/staking/IStakingService.sol +7 -16
- package/contracts/staking/Staking.sol +4 -4
- package/contracts/staking/StakingService.sol +2 -3
- package/contracts/staking/StakingStore.sol +3 -3
- package/contracts/staking/TargetHandler.sol +2 -2
- package/contracts/type/RequestId.sol +6 -0
- package/contracts/type/RiskId.sol +8 -8
- package/contracts/upgradeability/ProxyManager.sol +2 -2
- package/package.json +3 -3
| @@ -22,6 +22,7 @@ import {InstanceStore} from "./InstanceStore.sol"; | |
| 22 22 | 
             
            import {NftId} from "../type/NftId.sol";
         | 
| 23 23 | 
             
            import {ObjectType, INSTANCE, COMPONENT, INSTANCE, REGISTRY, STAKING} from "../type/ObjectType.sol";
         | 
| 24 24 | 
             
            import {ProductStore} from "./ProductStore.sol";
         | 
| 25 | 
            +
            import {RequestSet} from "./RequestSet.sol";
         | 
| 25 26 | 
             
            import {RiskSet} from "./RiskSet.sol";
         | 
| 26 27 | 
             
            import {RoleId} from "../type/RoleId.sol";
         | 
| 27 28 | 
             
            import {Seconds} from "../type/Seconds.sol";
         | 
| @@ -49,6 +50,7 @@ contract InstanceService is | |
| 49 50 | 
             
                address internal _masterInstanceReader;
         | 
| 50 51 | 
             
                address internal _masterInstanceBundleSet;
         | 
| 51 52 | 
             
                address internal _masterInstanceRiskSet;
         | 
| 53 | 
            +
                address internal _masterInstanceRequestSet;
         | 
| 52 54 | 
             
                address internal _masterInstanceStore;
         | 
| 53 55 | 
             
                address internal _masterProductStore;
         | 
| 54 56 |  | 
| @@ -304,11 +306,13 @@ contract InstanceService is | |
| 304 306 | 
             
                    InstanceReader upgradedInstanceReaderClone = InstanceReader(
         | 
| 305 307 | 
             
                        Clones.clone(address(_masterInstanceReader)));
         | 
| 306 308 |  | 
| 309 | 
            +
                    address oldInstanceReaderAddress = address(instance.getInstanceReader());
         | 
| 307 310 | 
             
                    upgradedInstanceReaderClone.initializeWithInstance(instanceAddress);
         | 
| 308 311 | 
             
                    instance.setInstanceReader(upgradedInstanceReaderClone);
         | 
| 309 312 |  | 
| 310 313 | 
             
                    emit LogInstanceServiceInstanceReaderUpgraded(
         | 
| 311 314 | 
             
                        getRegistry().getNftIdForAddress(instanceAddress),
         | 
| 315 | 
            +
                        oldInstanceReaderAddress,
         | 
| 312 316 | 
             
                        address(upgradedInstanceReaderClone));
         | 
| 313 317 | 
             
                }
         | 
| 314 318 |  | 
| @@ -323,55 +327,80 @@ contract InstanceService is | |
| 323 327 | 
             
                    if(_masterInstanceAdmin != address(0)) { revert ErrorInstanceServiceMasterInstanceAdminAlreadySet(); }
         | 
| 324 328 | 
             
                    if(_masterInstanceBundleSet != address(0)) { revert ErrorInstanceServiceMasterBundleSetAlreadySet(); }
         | 
| 325 329 | 
             
                    if(_masterInstanceRiskSet != address(0)) { revert ErrorInstanceServiceMasterRiskSetAlreadySet(); }
         | 
| 330 | 
            +
                    if(_masterInstanceRequestSet != address(0)) { revert ErrorInstanceServiceMasterRequestSetAlreadySet(); }
         | 
| 326 331 | 
             
                    if(instanceAddress == address(0)) { revert ErrorInstanceServiceInstanceAddressZero(); }
         | 
| 327 332 |  | 
| 328 333 | 
             
                    {
         | 
| 329 334 | 
             
                        IInstance instance = IInstance(instanceAddress);
         | 
| 330 335 | 
             
                        address accessManagerAddress = instance.authority();
         | 
| 331 336 | 
             
                        InstanceAdmin instanceAdmin = instance.getInstanceAdmin();
         | 
| 332 | 
            -
                        address instanceAdminAddress = address(instanceAdmin);
         | 
| 333 | 
            -
                        InstanceReader instanceReader = instance.getInstanceReader();
         | 
| 334 | 
            -
                        address instanceReaderAddress = address(instanceReader);
         | 
| 335 | 
            -
                        BundleSet bundleSet = instance.getBundleSet();
         | 
| 336 | 
            -
                        address bundleSetAddress = address(bundleSet);
         | 
| 337 | 
            -
                        RiskSet riskSet = instance.getRiskSet();
         | 
| 338 | 
            -
                        address riskSetAddress = address(riskSet);
         | 
| 339 | 
            -
                        InstanceStore instanceStore = instance.getInstanceStore();
         | 
| 340 | 
            -
                        address instanceStoreAddress = address(instanceStore);
         | 
| 341 | 
            -
                        ProductStore productStore = instance.getProductStore();
         | 
| 342 | 
            -
                        address productStoreAddress = address(productStore);
         | 
| 343 | 
            -
             | 
| 344 | 
            -
                        if(accessManagerAddress == address(0)) { revert ErrorInstanceServiceAccessManagerZero(); }
         | 
| 345 | 
            -
                        if(instanceAdminAddress == address(0)) { revert ErrorInstanceServiceInstanceAdminZero(); }
         | 
| 346 | 
            -
                        if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderZero(); }
         | 
| 347 | 
            -
                        if(bundleSetAddress == address(0)) { revert ErrorInstanceServiceBundleSetZero(); }
         | 
| 348 | 
            -
                        if(riskSetAddress == address(0)) { revert ErrorInstanceServiceRiskSetZero(); }
         | 
| 349 | 
            -
                        if(instanceStoreAddress == address(0)) { revert ErrorInstanceServiceInstanceStoreZero(); }
         | 
| 350 | 
            -
                        if(productStoreAddress == address(0)) { revert ErrorInstanceServiceProductStoreZero(); } // TODO: rename exception
         | 
| 351 337 |  | 
| 352 | 
            -
                         | 
| 353 | 
            -
             | 
| 354 | 
            -
             | 
| 355 | 
            -
             | 
| 356 | 
            -
             | 
| 357 | 
            -
             | 
| 358 | 
            -
             | 
| 359 | 
            -
             | 
| 360 | 
            -
             | 
| 361 | 
            -
             | 
| 362 | 
            -
             | 
| 363 | 
            -
             | 
| 364 | 
            -
             | 
| 365 | 
            -
             | 
| 366 | 
            -
             | 
| 367 | 
            -
             | 
| 368 | 
            -
                         | 
| 338 | 
            +
                        {
         | 
| 339 | 
            +
                            address instanceAdminAddress = address(instanceAdmin);
         | 
| 340 | 
            +
                            InstanceReader instanceReader = instance.getInstanceReader();
         | 
| 341 | 
            +
                            address instanceReaderAddress = address(instanceReader);
         | 
| 342 | 
            +
             | 
| 343 | 
            +
                            if(accessManagerAddress == address(0)) { revert ErrorInstanceServiceAccessManagerZero(); }
         | 
| 344 | 
            +
                            if(instanceAdminAddress == address(0)) { revert ErrorInstanceServiceInstanceAdminZero(); }
         | 
| 345 | 
            +
                            if(instanceReaderAddress == address(0)) { revert ErrorInstanceServiceInstanceReaderZero(); }
         | 
| 346 | 
            +
             | 
| 347 | 
            +
                            if(instance.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceInstanceAuthorityMismatch(); }
         | 
| 348 | 
            +
                            if(instanceReader.getInstance() != instance) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch2(); }
         | 
| 349 | 
            +
                    
         | 
| 350 | 
            +
                            _masterAccessManager = accessManagerAddress;
         | 
| 351 | 
            +
                            _masterInstanceAdmin = instanceAdminAddress;
         | 
| 352 | 
            +
                            _masterInstance = instanceAddress;
         | 
| 353 | 
            +
                            _masterInstanceReader = instanceReaderAddress;
         | 
| 354 | 
            +
                        }
         | 
| 355 | 
            +
             | 
| 356 | 
            +
                        {
         | 
| 357 | 
            +
                            BundleSet bundleSet = instance.getBundleSet();
         | 
| 358 | 
            +
                            address bundleSetAddress = address(bundleSet);
         | 
| 359 | 
            +
                            RiskSet riskSet = instance.getRiskSet();
         | 
| 360 | 
            +
                            address riskSetAddress = address(riskSet);
         | 
| 361 | 
            +
                            RequestSet requestSet = instance.getRequestSet();
         | 
| 362 | 
            +
                            address requestSetAddress = address(requestSet);
         | 
| 363 | 
            +
                        
         | 
| 364 | 
            +
                            if(bundleSetAddress == address(0)) { revert ErrorInstanceServiceBundleSetZero(); }
         | 
| 365 | 
            +
                            if(riskSetAddress == address(0)) { revert ErrorInstanceServiceRiskSetZero(); }
         | 
| 366 | 
            +
                            if(requestSetAddress == address(0)) { revert ErrorInstanceServiceRequestSetZero(); }
         | 
| 367 | 
            +
                            if(bundleSet.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceBundleSetAuthorityMismatch(); }
         | 
| 368 | 
            +
                            if(riskSet.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceRiskSetAuthorityMismatch(); }
         | 
| 369 | 
            +
                            if(requestSet.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceRequestSetAuthorityMismatch(); }
         | 
| 370 | 
            +
                            if(bundleSet.getInstanceAddress() != address(instance)) { revert ErrorInstanceServiceBundleSetInstanceMismatch(); }
         | 
| 371 | 
            +
                            if(riskSet.getInstanceAddress() != address(instance)) { revert ErrorInstanceServiceRiskSetInstanceMismatch(); }
         | 
| 372 | 
            +
                            if(requestSet.getInstanceAddress() != address(instance)) { revert ErrorInstanceServiceRequestSetInstanceMismatch(); }
         | 
| 373 | 
            +
             | 
| 374 | 
            +
                            _masterInstanceBundleSet = bundleSetAddress;
         | 
| 375 | 
            +
                            _masterInstanceRiskSet = riskSetAddress;
         | 
| 376 | 
            +
                            _masterInstanceRequestSet = requestSetAddress;
         | 
| 377 | 
            +
                        }
         | 
| 378 | 
            +
             | 
| 379 | 
            +
                        {
         | 
| 380 | 
            +
                            InstanceStore instanceStore = instance.getInstanceStore();
         | 
| 381 | 
            +
                            address instanceStoreAddress = address(instanceStore);
         | 
| 382 | 
            +
                            ProductStore productStore = instance.getProductStore();
         | 
| 383 | 
            +
                            address productStoreAddress = address(productStore);
         | 
| 384 | 
            +
             | 
| 385 | 
            +
                            if(instanceStoreAddress == address(0)) { revert ErrorInstanceServiceInstanceStoreZero(); }
         | 
| 386 | 
            +
                            if(productStoreAddress == address(0)) { revert ErrorInstanceServiceProductStoreZero(); } // TODO: rename exception
         | 
| 387 | 
            +
                            
         | 
| 388 | 
            +
                            if(instanceStore.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceInstanceStoreAuthorityMismatch(); }
         | 
| 389 | 
            +
                            if(productStore.authority() != instanceAdmin.authority()) { revert ErrorInstanceServiceProductStoreAuthorityMismatch(); } 
         | 
| 390 | 
            +
                            
         | 
| 391 | 
            +
                            _masterInstanceStore = instanceStoreAddress;
         | 
| 392 | 
            +
                            _masterProductStore = productStoreAddress;
         | 
| 393 | 
            +
                        }
         | 
| 369 394 | 
             
                    }
         | 
| 370 395 |  | 
| 371 396 | 
             
                    {
         | 
| 372 397 | 
             
                        IInstance masterInstance = IInstance(_masterInstance);
         | 
| 373 398 | 
             
                        IRegistry.ObjectInfo memory info = _registryService.registerInstance(masterInstance, getOwner());
         | 
| 374 399 | 
             
                        masterInstanceNftId = info.nftId;
         | 
| 400 | 
            +
                        
         | 
| 401 | 
            +
                        emit LogInstanceServiceMasterInstanceRegistered(
         | 
| 402 | 
            +
                            masterInstanceNftId, _masterInstance, _masterInstanceAdmin, _masterAccessManager, 
         | 
| 403 | 
            +
                            _masterInstanceReader, _masterInstanceBundleSet, _masterInstanceRiskSet, _masterInstanceRequestSet, _masterInstanceStore, _masterProductStore);
         | 
| 375 404 | 
             
                    }
         | 
| 376 405 | 
             
                }
         | 
| 377 406 |  | 
| @@ -388,10 +417,12 @@ contract InstanceService is | |
| 388 417 | 
             
                    InstanceReader instanceReader = InstanceReader(instanceReaderAddress);
         | 
| 389 418 | 
             
                    if(instanceReader.getInstance() != IInstance(_masterInstance)) { revert ErrorInstanceServiceInstanceReaderInstanceMismatch(); }
         | 
| 390 419 |  | 
| 420 | 
            +
                    address oldMasterInstanceReaderAddress = _masterInstanceReader;
         | 
| 391 421 | 
             
                    _masterInstanceReader = instanceReaderAddress;
         | 
| 392 422 |  | 
| 393 423 | 
             
                    emit LogInstanceServiceMasterInstanceReaderUpgraded(
         | 
| 394 424 | 
             
                        getRegistry().getNftIdForAddress(_masterInstance),
         | 
| 425 | 
            +
                        oldMasterInstanceReaderAddress,
         | 
| 395 426 | 
             
                        instanceReaderAddress);
         | 
| 396 427 | 
             
                }
         | 
| 397 428 |  | 
| @@ -443,6 +474,7 @@ contract InstanceService is | |
| 443 474 | 
             
                            productStore: ProductStore(Clones.clone(address(_masterProductStore))),
         | 
| 444 475 | 
             
                            bundleSet: BundleSet(Clones.clone(_masterInstanceBundleSet)),
         | 
| 445 476 | 
             
                            riskSet: RiskSet(Clones.clone(_masterInstanceRiskSet)),
         | 
| 477 | 
            +
                            requestSet: RequestSet(Clones.clone(address(_masterInstanceRequestSet))),
         | 
| 446 478 | 
             
                            instanceReader: InstanceReader(Clones.clone(address(_masterInstanceReader)))
         | 
| 447 479 | 
             
                        }),
         | 
| 448 480 | 
             
                        getRegistry(),
         | 
| @@ -34,20 +34,20 @@ contract InstanceStore is | |
| 34 34 | 
             
                BaseStore
         | 
| 35 35 | 
             
            {
         | 
| 36 36 |  | 
| 37 | 
            -
                event LogProductStoreComponentInfoCreated(NftId componentNftId, StateId state, address createdby, address txOrigin);
         | 
| 38 | 
            -
                event LogProductStoreComponentInfoUpdated(NftId componentNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 39 | 
            -
                event LogProductStorePoolInfoCreated(NftId poolNftId, StateId state, address createdBy, address txOrigin);
         | 
| 40 | 
            -
                event LogProductStorePoolInfoUpdated(NftId poolNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 41 | 
            -
                event LogProductStoreDistributorTypeInfoCreated(DistributorType distributorType, StateId state, address createdBy, address txOrigin);
         | 
| 42 | 
            -
                event LogProductStoreDistributorTypeInfoUpdated(DistributorType distributorType, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 43 | 
            -
                event LogProductStoreDistributorInfoCreated(NftId distributorNftId, StateId state, address createdBy, address txOrigin);
         | 
| 44 | 
            -
                event LogProductStoreDistributorInfoUpdated(NftId distributorNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 45 | 
            -
                event LogProductStoreReferralInfoCreated(ReferralId referralId, StateId state, address createdBy, address txOrigin);
         | 
| 46 | 
            -
                event LogProductStoreReferralInfoUpdated(ReferralId referralId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 47 | 
            -
                event LogProductStoreBundleInfoCreated(NftId bundleNftId, StateId state, address createdBy, address txOrigin);
         | 
| 48 | 
            -
                event LogProductStoreBundleInfoUpdated(NftId bundleNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 49 | 
            -
                event LogProductStoreRequestInfoCreated(RequestId requestId, StateId state, address createdBy, address txOrigin);
         | 
| 50 | 
            -
                event LogProductStoreRequestInfoUpdated(RequestId requestId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 37 | 
            +
                event LogProductStoreComponentInfoCreated(NftId indexed componentNftId, StateId indexed state, address indexed createdby, address txOrigin);
         | 
| 38 | 
            +
                event LogProductStoreComponentInfoUpdated(NftId indexed componentNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 39 | 
            +
                event LogProductStorePoolInfoCreated(NftId indexed poolNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 40 | 
            +
                event LogProductStorePoolInfoUpdated(NftId indexed poolNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 41 | 
            +
                event LogProductStoreDistributorTypeInfoCreated(DistributorType indexed distributorType, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 42 | 
            +
                event LogProductStoreDistributorTypeInfoUpdated(DistributorType indexed distributorType, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 43 | 
            +
                event LogProductStoreDistributorInfoCreated(NftId indexed distributorNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 44 | 
            +
                event LogProductStoreDistributorInfoUpdated(NftId indexed distributorNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 45 | 
            +
                event LogProductStoreReferralInfoCreated(ReferralId indexed referralId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 46 | 
            +
                event LogProductStoreReferralInfoUpdated(ReferralId indexed referralId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 47 | 
            +
                event LogProductStoreBundleInfoCreated(NftId indexed bundleNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 48 | 
            +
                event LogProductStoreBundleInfoUpdated(NftId indexed bundleNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 49 | 
            +
                event LogProductStoreRequestInfoCreated(RequestId indexed requestId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 50 | 
            +
                event LogProductStoreRequestInfoUpdated(RequestId indexed requestId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 51 51 |  | 
| 52 52 |  | 
| 53 53 | 
             
                mapping(Key32 => IComponents.ComponentInfo) private _components;
         | 
| @@ -29,20 +29,20 @@ contract ProductStore is | |
| 29 29 | 
             
                ObjectCounter,
         | 
| 30 30 | 
             
                ObjectLifecycle
         | 
| 31 31 | 
             
            {
         | 
| 32 | 
            -
                event LogProductStoreProductInfoCreated(NftId productNftId, StateId state, address createdBy, address txOrigin);
         | 
| 33 | 
            -
                event LogProductStoreProductInfoUpdated(NftId productNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 34 | 
            -
                event LogProductStoreFeeInfoCreated(NftId productNftId, StateId state, address createdBy, address txOrigin);
         | 
| 35 | 
            -
                event LogProductStoreFeeInfoUpdated(NftId productNftId, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 36 | 
            -
                event LogProductStoreRiskInfoCreated(RiskId riskId, StateId state, address createdBy, address txOrigin);
         | 
| 37 | 
            -
                event LogProductStoreRiskInfoUpdated(RiskId riskId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 38 | 
            -
                event LogProductStorePolicyInfoCreated(NftId policyNftId, StateId state, address createdBy, address txOrigin);
         | 
| 39 | 
            -
                event LogProductStorePolicyInfoUpdated(NftId policyNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 40 | 
            -
                event LogProductStorePremiumInfoCreated(NftId policyNftId, StateId state, address createdBy, address txOrigin);
         | 
| 41 | 
            -
                event LogProductStorePremiumInfoUpdated(NftId policyNftId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 42 | 
            -
                event LogProductStoreClaimInfoCreated(NftId policyNftId, ClaimId claimId, StateId state, address createdBy, address txOrigin);
         | 
| 43 | 
            -
                event LogProductStoreClaimInfoUpdated(NftId policyNftId, ClaimId claimId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 44 | 
            -
                event LogProductStorePayoutInfoCreated(NftId policyNftId, PayoutId payoutId, StateId state, address createdBy, address txOrigin);
         | 
| 45 | 
            -
                event LogProductStorePayoutInfoUpdated(NftId policyNftId, PayoutId payoutId, StateId oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 32 | 
            +
                event LogProductStoreProductInfoCreated(NftId indexed productNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 33 | 
            +
                event LogProductStoreProductInfoUpdated(NftId indexed productNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 34 | 
            +
                event LogProductStoreFeeInfoCreated(NftId indexed productNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 35 | 
            +
                event LogProductStoreFeeInfoUpdated(NftId indexed productNftId, address indexed updatedBy, address indexed txOrigin, Blocknumber lastUpdatedIn);
         | 
| 36 | 
            +
                event LogProductStoreRiskInfoCreated(RiskId indexed riskId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 37 | 
            +
                event LogProductStoreRiskInfoUpdated(RiskId indexed riskId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 38 | 
            +
                event LogProductStorePolicyInfoCreated(NftId indexed policyNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 39 | 
            +
                event LogProductStorePolicyInfoUpdated(NftId indexed policyNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 40 | 
            +
                event LogProductStorePremiumInfoCreated(NftId indexed policyNftId, StateId indexed state, address indexed createdBy, address txOrigin);
         | 
| 41 | 
            +
                event LogProductStorePremiumInfoUpdated(NftId indexed policyNftId, StateId indexed oldState, StateId indexed newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 42 | 
            +
                event LogProductStoreClaimInfoCreated(NftId indexed policyNftId, ClaimId indexed claimId, StateId indexed state, address createdBy, address txOrigin);
         | 
| 43 | 
            +
                event LogProductStoreClaimInfoUpdated(NftId indexed policyNftId, ClaimId indexed claimId, StateId indexed oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 44 | 
            +
                event LogProductStorePayoutInfoCreated(NftId indexed policyNftId, PayoutId indexed payoutId, StateId indexed state, address createdBy, address txOrigin);
         | 
| 45 | 
            +
                event LogProductStorePayoutInfoUpdated(NftId indexed policyNftId, PayoutId indexed payoutId, StateId indexed oldState, StateId newState, address updatedBy, address txOrigin, Blocknumber lastUpdatedIn);
         | 
| 46 46 |  | 
| 47 47 | 
             
                mapping(Key32 key32 => IComponents.ProductInfo) private _products;
         | 
| 48 48 | 
             
                mapping(Key32 key32 => IComponents.FeeInfo) private _fees;
         | 
| @@ -113,7 +113,8 @@ contract ProductStore is | |
| 113 113 | 
             
                }
         | 
| 114 114 |  | 
| 115 115 | 
             
                //--- Risk --------------------------------------------------------------//
         | 
| 116 | 
            -
                function createRisk( | 
| 116 | 
            +
                function createRisk(IRisk.RiskInfo memory info) external restricted() returns (RiskId riskId) {
         | 
| 117 | 
            +
                    riskId = _createNextRiskId();
         | 
| 117 118 | 
             
                    Key32 key = riskId.toKey32();
         | 
| 118 119 | 
             
                    _createMetadata(key);
         | 
| 119 120 | 
             
                    _risks[key] = info;
         | 
| @@ -0,0 +1,63 @@ | |
| 1 | 
            +
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 | 
            +
            pragma solidity ^0.8.20;
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            import {IComponents} from "./module/IComponents.sol";
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            import {Key32} from "../type/Key32.sol";
         | 
| 7 | 
            +
            import {LibNftIdSet} from "../type/NftIdSet.sol";
         | 
| 8 | 
            +
            import {LibRequestIdSet} from "../type/RequestIdSet.sol";
         | 
| 9 | 
            +
            import {NftId} from "../type/NftId.sol";
         | 
| 10 | 
            +
            import {ObjectSet} from "./base/ObjectSet.sol";
         | 
| 11 | 
            +
            import {ObjectSetHelperLib} from "./base/ObjectSetHelperLib.sol";
         | 
| 12 | 
            +
            import {RequestId, RequestIdLib} from "../type/RequestId.sol";
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            contract RequestSet is 
         | 
| 15 | 
            +
                ObjectSet
         | 
| 16 | 
            +
            {
         | 
| 17 | 
            +
                using LibNftIdSet for LibNftIdSet.Set;
         | 
| 18 | 
            +
                using LibRequestIdSet for LibRequestIdSet.Set;
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                event LogRequestSetRequestAdded(NftId indexed oracleNftId, RequestId indexed requestId);
         | 
| 21 | 
            +
                event LogRequestSetRequestRemoved(NftId indexed oracleNftId, RequestId indexed requestId);
         | 
| 22 | 
            +
             | 
| 23 | 
            +
                error ErrorRequestSetOracleNotRegistered(NftId oracleNftId);
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                /// @dev add a new request to a oracle registerd with this instance
         | 
| 26 | 
            +
                // the corresponding oracles existence is checked via instance reader
         | 
| 27 | 
            +
                function add(NftId oracleNftId, RequestId requestId) external restricted() {
         | 
| 28 | 
            +
                    IComponents.ComponentInfo memory componentInfo = ObjectSetHelperLib.getComponentInfo(_instanceAddress, oracleNftId);
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                    // ensure pool is registered with instance
         | 
| 31 | 
            +
                    if (bytes(componentInfo.name).length == 0) {
         | 
| 32 | 
            +
                        revert ErrorRequestSetOracleNotRegistered(oracleNftId);
         | 
| 33 | 
            +
                    }
         | 
| 34 | 
            +
             | 
| 35 | 
            +
                    _add(oracleNftId, _toRequestKey32(requestId));
         | 
| 36 | 
            +
                    emit LogRequestSetRequestAdded(oracleNftId, requestId);
         | 
| 37 | 
            +
                }
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                function remove(NftId oracleNftId, RequestId requestId) external restricted() {
         | 
| 40 | 
            +
                    _remove(oracleNftId, _toRequestKey32(requestId));
         | 
| 41 | 
            +
                    emit LogRequestSetRequestRemoved(oracleNftId, requestId);
         | 
| 42 | 
            +
                }
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                function _toRequestKey32(RequestId requestId) private pure returns (Key32) {
         | 
| 45 | 
            +
                    return requestId.toKey32();
         | 
| 46 | 
            +
                }
         | 
| 47 | 
            +
             | 
| 48 | 
            +
                function activeRequests(NftId oracleNftId) external view returns (uint256 numberOfRequests) {
         | 
| 49 | 
            +
                    return _objects(oracleNftId);
         | 
| 50 | 
            +
                }
         | 
| 51 | 
            +
             | 
| 52 | 
            +
                function activeRequestAt(NftId oracleNftId, uint256 idx) external view returns (RequestId requestId) {
         | 
| 53 | 
            +
                    return _toRequestId(_getActiveObject(oracleNftId, idx));
         | 
| 54 | 
            +
                }
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                function contains(NftId oracleNftId, RequestId requestId) external view returns (bool) {
         | 
| 57 | 
            +
                    return _contains(oracleNftId, _toRequestKey32(requestId));
         | 
| 58 | 
            +
                }
         | 
| 59 | 
            +
             | 
| 60 | 
            +
                function _toRequestId(Key32 key) private pure returns (RequestId) {
         | 
| 61 | 
            +
                    return RequestIdLib.toRequestId(key.toKeyId());
         | 
| 62 | 
            +
                }
         | 
| 63 | 
            +
            }
         | 
| @@ -13,12 +13,11 @@ contract RiskSet is | |
| 13 13 | 
             
                ObjectSet
         | 
| 14 14 | 
             
            {
         | 
| 15 15 |  | 
| 16 | 
            -
                event LogRiskSetPolicyLinked(RiskId riskId, NftId policyNftId);
         | 
| 17 | 
            -
                event LogRiskSetPolicyUnlinked(RiskId riskId, NftId policyNftId);
         | 
| 16 | 
            +
                event LogRiskSetPolicyLinked(RiskId indexed riskId, NftId indexed policyNftId);
         | 
| 17 | 
            +
                event LogRiskSetPolicyUnlinked(RiskId indexed riskId, NftId indexed policyNftId);
         | 
| 18 18 |  | 
| 19 | 
            -
                event LogRiskSetRiskAdded(NftId productNftId, RiskId riskId);
         | 
| 20 | 
            -
                event  | 
| 21 | 
            -
                event LogRiskSetRiskPaused(NftId poolNftId,  RiskId riskId);
         | 
| 19 | 
            +
                event LogRiskSetRiskAdded(NftId indexed productNftId, RiskId indexed riskId);
         | 
| 20 | 
            +
                event LogRiskSetRiskActivated(NftId indexed poolNftId,  RiskId indexed riskId, bool indexed active);
         | 
| 22 21 |  | 
| 23 22 | 
             
                error ErrorRiskSetRiskLocked(RiskId riskId, NftId policyNftId); 
         | 
| 24 23 | 
             
                error ErrorRiskSetRiskUnknown(RiskId riskId);
         | 
| @@ -68,14 +67,14 @@ contract RiskSet is | |
| 68 67 | 
             
                function activate(RiskId riskId) external restricted() {
         | 
| 69 68 | 
             
                    NftId productNftId = ObjectSetHelperLib.getProductNftId(_instanceAddress, riskId);
         | 
| 70 69 | 
             
                    _activate(productNftId, riskId.toKey32());
         | 
| 71 | 
            -
                    emit  | 
| 70 | 
            +
                    emit LogRiskSetRiskActivated(productNftId, riskId, true);
         | 
| 72 71 | 
             
                }
         | 
| 73 72 |  | 
| 74 73 | 
             
                /// @dev Applications linked to paused/archived risks may not be underwritten
         | 
| 75 74 | 
             
                function deactivate(RiskId riskId) external restricted() {
         | 
| 76 75 | 
             
                    NftId productNftId = ObjectSetHelperLib.getProductNftId(_instanceAddress, riskId);
         | 
| 77 76 | 
             
                    _deactivate(productNftId, riskId.toKey32());
         | 
| 78 | 
            -
                    emit  | 
| 77 | 
            +
                    emit LogRiskSetRiskActivated(productNftId, riskId, false);
         | 
| 79 78 | 
             
                }
         | 
| 80 79 |  | 
| 81 80 | 
             
                function checkRisk(NftId productNftId, RiskId riskId)
         | 
| @@ -7,4 +7,5 @@ string constant INSTANCE_STORE_TARGET_NAME = "InstanceStore"; | |
| 7 7 | 
             
            string constant PRODUCT_STORE_TARGET_NAME = "ProductStore";
         | 
| 8 8 | 
             
            string constant BUNDLE_SET_TARGET_NAME = "BundleSet";
         | 
| 9 9 | 
             
            string constant RISK_SET_TARGET_NAME = "RiskSet";
         | 
| 10 | 
            +
            string constant REQUEST_SET_TARGET_NAME = "RequestSet";
         | 
| 10 11 |  | 
| @@ -10,16 +10,16 @@ contract BalanceStore { | |
| 10 10 | 
             
                error ErrorBalanceStoreTargetAlreadyRegistered(NftId targetNftId);
         | 
| 11 11 | 
             
                error ErrorBalanceStoreTargetNotRegistered(NftId targetNftId);
         | 
| 12 12 |  | 
| 13 | 
            -
                event LogBalanceStoreTargetRegistered(NftId targetNftId);
         | 
| 13 | 
            +
                event LogBalanceStoreTargetRegistered(NftId indexed targetNftId);
         | 
| 14 14 |  | 
| 15 | 
            -
                event LogBalanceStoreFeesIncreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 16 | 
            -
                event LogBalanceStoreFeesDecreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 15 | 
            +
                event LogBalanceStoreFeesIncreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 16 | 
            +
                event LogBalanceStoreFeesDecreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 17 17 |  | 
| 18 | 
            -
                event LogBalanceStoreLockedIncreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 19 | 
            -
                event LogBalanceStoreLockedDecreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 18 | 
            +
                event LogBalanceStoreLockedIncreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 19 | 
            +
                event LogBalanceStoreLockedDecreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 20 20 |  | 
| 21 | 
            -
                event LogBalanceStoreBalanceIncreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 22 | 
            -
                event LogBalanceStoreBalanceDecreased(NftId targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 21 | 
            +
                event LogBalanceStoreBalanceIncreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 22 | 
            +
                event LogBalanceStoreBalanceDecreased(NftId indexed targetNftId, Amount addedAmount, Amount newBalance, Blocknumber lastUpdatedIn);
         | 
| 23 23 |  | 
| 24 24 | 
             
                mapping(NftId nftId => Amount balance) private _balanceAmount;
         | 
| 25 25 | 
             
                mapping(NftId nftId => Amount locked) private _lockedAmount;
         | 
| @@ -1,20 +1,22 @@ | |
| 1 1 | 
             
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 | 
            -
            import {Blocknumber, BlocknumberLib} from "../../type/Blocknumber.sol";
         | 
| 5 4 | 
             
            import {NftId} from "../../type/NftId.sol";
         | 
| 6 | 
            -
            import {Amount} from "../../type/Amount.sol";
         | 
| 7 5 | 
             
            import {RequestId, RequestIdLib} from "../../type/RequestId.sol";
         | 
| 6 | 
            +
            import {RiskId, RiskIdLib} from "../../type/RiskId.sol";
         | 
| 8 7 |  | 
| 9 8 | 
             
            contract ObjectCounter {
         | 
| 10 9 |  | 
| 11 | 
            -
                 | 
| 12 | 
            -
                // mapping(NftId productNftId => uint64 risks) private _riskCounter;
         | 
| 13 | 
            -
             | 
| 10 | 
            +
                uint64 private _riskCounter = 0;
         | 
| 14 11 | 
             
                uint256 private _requestCounter = 0;
         | 
| 15 12 |  | 
| 16 13 | 
             
                function _createNextRequestId() internal returns (RequestId requestId) {
         | 
| 17 14 | 
             
                    _requestCounter++;
         | 
| 18 15 | 
             
                    requestId = RequestIdLib.toRequestId(_requestCounter);
         | 
| 19 16 | 
             
                }
         | 
| 17 | 
            +
             | 
| 18 | 
            +
                function _createNextRiskId() internal returns (RiskId riskId) {
         | 
| 19 | 
            +
                    _riskCounter++;
         | 
| 20 | 
            +
                    riskId = RiskIdLib.toRiskId(_riskCounter);
         | 
| 21 | 
            +
                }
         | 
| 20 22 | 
             
            }
         | 
| @@ -12,7 +12,7 @@ contract ObjectSet is | |
| 12 12 | 
             
            {
         | 
| 13 13 | 
             
                using LibKey32Set for LibKey32Set.Set;
         | 
| 14 14 |  | 
| 15 | 
            -
                event LogObjectSetInitialized(address instance);
         | 
| 15 | 
            +
                event LogObjectSetInitialized(address indexed instance);
         | 
| 16 16 |  | 
| 17 17 | 
             
                error ErrorObjectSetNftIdInvalid(NftId instanceNftId);
         | 
| 18 18 |  | 
| @@ -43,6 +43,14 @@ contract ObjectSet is | |
| 43 43 | 
             
                    activeSet.add(key);
         | 
| 44 44 | 
             
                }
         | 
| 45 45 |  | 
| 46 | 
            +
                function _remove(NftId componentNftId, Key32 key) internal {
         | 
| 47 | 
            +
                    LibKey32Set.Set storage allSet = _allObjects[componentNftId];
         | 
| 48 | 
            +
                    LibKey32Set.Set storage activeSet = _activeObjects[componentNftId];
         | 
| 49 | 
            +
             | 
| 50 | 
            +
                    allSet.remove(key);
         | 
| 51 | 
            +
                    activeSet.remove(key);
         | 
| 52 | 
            +
                }
         | 
| 53 | 
            +
             | 
| 46 54 | 
             
                function _activate(NftId componentNftId, Key32 key) internal {
         | 
| 47 55 | 
             
                    _activeObjects[componentNftId].add(key);
         | 
| 48 56 | 
             
                }
         | 
| @@ -2,6 +2,7 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {IBundle} from "../module/IBundle.sol";
         | 
| 5 | 
            +
            import {IComponents} from "../module/IComponents.sol";
         | 
| 5 6 | 
             
            import {IInstance} from "../IInstance.sol";
         | 
| 6 7 | 
             
            import {IRisk} from "../module/IRisk.sol";
         | 
| 7 8 | 
             
            import {NftId} from "../../type/NftId.sol";
         | 
| @@ -11,7 +12,6 @@ import {RiskId} from "../../type/RiskId.sol"; | |
| 11 12 | 
             
            library ObjectSetHelperLib {
         | 
| 12 13 |  | 
| 13 14 | 
             
                function getRiskInfo(address instanceAddress, RiskId riskId) public view returns (IRisk.RiskInfo memory) {
         | 
| 14 | 
            -
             | 
| 15 15 | 
             
                    return IInstance(instanceAddress).getInstanceReader().getRiskInfo(riskId);
         | 
| 16 16 | 
             
                }
         | 
| 17 17 |  | 
| @@ -27,4 +27,8 @@ library ObjectSetHelperLib { | |
| 27 27 | 
             
                    return getBundleInfo(instanceAddress, bundleNftId).poolNftId;
         | 
| 28 28 | 
             
                }
         | 
| 29 29 |  | 
| 30 | 
            +
                function getComponentInfo(address instanceAddress, NftId componentNftId) public view returns (IComponents.ComponentInfo memory) {
         | 
| 31 | 
            +
                    return IInstance(instanceAddress).getInstanceReader().getComponentInfo(componentNftId);
         | 
| 32 | 
            +
                }
         | 
| 33 | 
            +
             | 
| 30 34 | 
             
            }
         | 
| @@ -13,6 +13,10 @@ import {Timestamp} from "../type/Timestamp.sol"; | |
| 13 13 | 
             
            interface IOracleComponent is IInstanceLinkedComponent {
         | 
| 14 14 | 
             
                error ErrorOracleNotImplemented(string methodName);
         | 
| 15 15 |  | 
| 16 | 
            +
                event LogOracleRequestReceived(RequestId indexed requestId, NftId indexed requesterId);
         | 
| 17 | 
            +
                event LogOracleRequestCancelled(RequestId indexed requestId);
         | 
| 18 | 
            +
             | 
| 19 | 
            +
             | 
| 16 20 | 
             
                /// @dev callback method for requesting some data from the oracle
         | 
| 17 21 | 
             
                function request(
         | 
| 18 22 | 
             
                    RequestId requestId,
         | 
| @@ -30,4 +34,10 @@ interface IOracleComponent is IInstanceLinkedComponent { | |
| 30 34 |  | 
| 31 35 | 
             
                /// @dev returns true iff the component needs to be called when selling/renewing policis
         | 
| 32 36 | 
             
                function isVerifying() external view returns (bool verifying);
         | 
| 37 | 
            +
             | 
| 38 | 
            +
                function activeRequests() external view returns(uint256 numberOfRequests);
         | 
| 39 | 
            +
                
         | 
| 40 | 
            +
                function getActiveRequest(uint256 idx) external view returns(RequestId requestId);
         | 
| 41 | 
            +
             | 
| 42 | 
            +
                function isActiveRequest(RequestId requestId) external view returns(bool isActive);
         | 
| 33 43 | 
             
            }
         | 
| @@ -11,11 +11,11 @@ import {Timestamp} from "../type/Timestamp.sol"; | |
| 11 11 |  | 
| 12 12 | 
             
            interface IOracleService is IService {
         | 
| 13 13 |  | 
| 14 | 
            -
                event LogOracleServiceRequestCreated(RequestId requestId, NftId requesterNftId, NftId oracleNftId, Timestamp expiryAt);
         | 
| 15 | 
            -
                event LogOracleServiceResponseProcessed(RequestId requestId, NftId oracleNftId);
         | 
| 16 | 
            -
                event LogOracleServiceDeliveryFailed(RequestId requestId, address requesterAddress, string functionSignature);
         | 
| 17 | 
            -
                event LogOracleServiceResponseResent(RequestId requestId, NftId requesterNftId);
         | 
| 18 | 
            -
                event LogOracleServiceRequestCancelled(RequestId requestId, NftId requesterNftId);
         | 
| 14 | 
            +
                event LogOracleServiceRequestCreated(RequestId indexed requestId, NftId indexed requesterNftId, NftId indexed oracleNftId, Timestamp expiryAt);
         | 
| 15 | 
            +
                event LogOracleServiceResponseProcessed(RequestId indexed requestId, NftId indexed requesterNftId, NftId indexed oracleNftId);
         | 
| 16 | 
            +
                event LogOracleServiceDeliveryFailed(RequestId indexed requestId, address indexed requesterAddress, string functionSignature);
         | 
| 17 | 
            +
                event LogOracleServiceResponseResent(RequestId indexed requestId, NftId indexed requesterNftId);
         | 
| 18 | 
            +
                event LogOracleServiceRequestCancelled(RequestId indexed requestId, NftId indexed requesterNftId);
         | 
| 19 19 |  | 
| 20 20 | 
             
                // create request
         | 
| 21 21 | 
             
                error ErrorOracleServiceProductMismatch(ObjectType callerObjectType, NftId productNft, NftId oracleParentNftId);
         | 
| @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {Amount} from "../type/Amount.sol";
         | 
| 5 | 
            -
            import {COMPONENT,  | 
| 5 | 
            +
            import {COMPONENT, ORACLE} from "../type/ObjectType.sol";
         | 
| 6 6 | 
             
            import {IAuthorization} from "../authorization/IAuthorization.sol";
         | 
| 7 7 | 
             
            import {IComponentService} from "../shared/IComponentService.sol";
         | 
| 8 8 | 
             
            import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
         | 
| @@ -63,7 +63,7 @@ abstract contract Oracle is | |
| 63 63 | 
             
                }
         | 
| 64 64 |  | 
| 65 65 | 
             
                /// @dev Not relevant for oracle components
         | 
| 66 | 
            -
                function withdrawFees(Amount | 
| 66 | 
            +
                function withdrawFees(Amount)
         | 
| 67 67 | 
             
                    external
         | 
| 68 68 | 
             
                    virtual
         | 
| 69 69 | 
             
                    override(IInstanceLinkedComponent, InstanceLinkedComponent)
         | 
| @@ -74,7 +74,32 @@ abstract contract Oracle is | |
| 74 74 | 
             
                    revert ErrorOracleNotImplemented("withdrawFees");
         | 
| 75 75 | 
             
                }
         | 
| 76 76 |  | 
| 77 | 
            +
                function activeRequests()
         | 
| 78 | 
            +
                    external
         | 
| 79 | 
            +
                    view
         | 
| 80 | 
            +
                    returns(uint256 numberOfRequests)
         | 
| 81 | 
            +
                {
         | 
| 82 | 
            +
                    return _getInstanceReader().getActiveRequests(getNftId());
         | 
| 83 | 
            +
                }
         | 
| 77 84 |  | 
| 85 | 
            +
             | 
| 86 | 
            +
                function getActiveRequest(uint256 idx)
         | 
| 87 | 
            +
                    external
         | 
| 88 | 
            +
                    view
         | 
| 89 | 
            +
                    returns(RequestId requestId)
         | 
| 90 | 
            +
                {
         | 
| 91 | 
            +
                    return _getInstanceReader().getActiveRequestAt(getNftId(), idx);
         | 
| 92 | 
            +
                }
         | 
| 93 | 
            +
             | 
| 94 | 
            +
                function isActiveRequest(RequestId requestId)
         | 
| 95 | 
            +
                    external
         | 
| 96 | 
            +
                    view
         | 
| 97 | 
            +
                    returns(bool isActive)
         | 
| 98 | 
            +
                {
         | 
| 99 | 
            +
                    return _getInstanceReader().isRequestActive(getNftId(), requestId);
         | 
| 100 | 
            +
                }
         | 
| 101 | 
            +
             | 
| 102 | 
            +
                // solhint-disable-next-line func-name-mixedcase
         | 
| 78 103 | 
             
                function __Oracle_init(
         | 
| 79 104 | 
             
                    address registry,
         | 
| 80 105 | 
             
                    NftId productNftId,
         | 
| @@ -102,49 +127,48 @@ abstract contract Oracle is | |
| 102 127 | 
             
                    _registerInterface(type(IOracleComponent).interfaceId);
         | 
| 103 128 | 
             
                }
         | 
| 104 129 |  | 
| 105 | 
            -
             | 
| 106 | 
            -
                ///  | 
| 107 | 
            -
                ///  | 
| 108 | 
            -
                 | 
| 109 | 
            -
                function _request(
         | 
| 130 | 
            +
                /// @dev Internal function for handling oracle responses.
         | 
| 131 | 
            +
                /// Default implementation sends response back to oracle service.
         | 
| 132 | 
            +
                /// Use this function in use case specific external/public functions to handle use case specific response handling.
         | 
| 133 | 
            +
                function _respond(
         | 
| 110 134 | 
             
                    RequestId requestId,
         | 
| 111 | 
            -
                     | 
| 112 | 
            -
                    bytes calldata requestData,
         | 
| 113 | 
            -
                    Timestamp expiryAt
         | 
| 135 | 
            +
                    bytes memory responseData
         | 
| 114 136 | 
             
                )
         | 
| 115 137 | 
             
                    internal
         | 
| 116 138 | 
             
                    virtual
         | 
| 117 139 | 
             
                {
         | 
| 140 | 
            +
                    _getOracleStorage()._oracleService.respond(requestId, responseData);
         | 
| 118 141 | 
             
                }
         | 
| 119 142 |  | 
| 120 | 
            -
             | 
| 121 | 
            -
                ///  | 
| 122 | 
            -
                 | 
| 123 | 
            -
             | 
| 124 | 
            -
             | 
| 125 | 
            -
                     | 
| 143 | 
            +
                /// @dev use case specific handling of oracle requests
         | 
| 144 | 
            +
                /// for now only log is emitted to verify that request has been received by oracle component 
         | 
| 145 | 
            +
                function _request(
         | 
| 146 | 
            +
                    RequestId requestId,
         | 
| 147 | 
            +
                    NftId requesterId,
         | 
| 148 | 
            +
                    bytes calldata,
         | 
| 149 | 
            +
                    Timestamp
         | 
| 126 150 | 
             
                )
         | 
| 127 151 | 
             
                    internal
         | 
| 128 | 
            -
                    virtual
         | 
| 152 | 
            +
                    virtual 
         | 
| 129 153 | 
             
                {
         | 
| 154 | 
            +
                    emit LogOracleRequestReceived(requestId, requesterId);
         | 
| 130 155 | 
             
                }
         | 
| 131 156 |  | 
| 132 157 |  | 
| 133 | 
            -
                /// @dev  | 
| 134 | 
            -
                ///  | 
| 135 | 
            -
                 | 
| 136 | 
            -
             | 
| 137 | 
            -
                    RequestId requestId,
         | 
| 138 | 
            -
                    bytes memory responseData
         | 
| 158 | 
            +
                /// @dev use case specific handling of oracle requests
         | 
| 159 | 
            +
                /// for now only log is emitted to verify that cancelling has been received by oracle component 
         | 
| 160 | 
            +
                function _cancel(
         | 
| 161 | 
            +
                    RequestId requestId
         | 
| 139 162 | 
             
                )
         | 
| 140 163 | 
             
                    internal
         | 
| 141 | 
            -
                    virtual
         | 
| 164 | 
            +
                    virtual 
         | 
| 142 165 | 
             
                {
         | 
| 143 | 
            -
                     | 
| 166 | 
            +
                    emit LogOracleRequestCancelled(requestId);
         | 
| 144 167 | 
             
                }
         | 
| 145 168 |  | 
| 146 169 |  | 
| 147 170 | 
             
                function _getOracleStorage() private pure returns (OracleStorage storage $) {
         | 
| 171 | 
            +
                    // solhint-disable-next-line no-inline-assembly
         | 
| 148 172 | 
             
                    assembly {
         | 
| 149 173 | 
             
                        $.slot := ORACLE_STORAGE_LOCATION_V1
         | 
| 150 174 | 
             
                    }
         |