@etherisc/gif-next 3.0.0-f0c22a5-010 → 3.0.0-f608233-662
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 +14 -14
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +44 -44
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +4 -4
- 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 +23 -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 +128 -140
- 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 +36 -48
- 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 +2366 -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 +49 -129
- 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 +2 -2
- 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 +2 -2
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +59 -179
- 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 +67 -142
- 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 +25 -100
- 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/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/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 +51 -13
- 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 +103 -36
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +94 -40
- 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 +121 -121
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +91 -91
- 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 +66 -79
- 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 +38 -2
- 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 +78 -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 +20 -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 +55 -43
- 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 +113 -101
- 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 +37 -37
- 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 +2 -77
- 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 +11 -11
- 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 +2 -2
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +2 -77
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +15 -28
- 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 +2 -2
- 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 +34 -34
- 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 +2 -77
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +37 -50
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +42 -42
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +4 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +14 -8
- 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 +55 -45
- 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 +10 -228
- 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 +30 -248
- 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 +2 -2
- 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/IAccountingService.sol +2 -2
- package/contracts/authorization/AccessAdmin.sol +10 -8
- package/contracts/authorization/AccessManagerCloneable.sol +1 -0
- package/contracts/authorization/IAccessAdmin.sol +9 -8
- package/contracts/distribution/DistributionService.sol +22 -19
- package/contracts/distribution/IDistributionComponent.sol +0 -2
- package/contracts/distribution/IDistributionService.sol +8 -8
- 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 +495 -0
- package/contracts/examples/crop/CropProductAuthorization.sol +69 -0
- package/contracts/examples/crop/Location.sol +50 -0
- package/contracts/examples/flight/FlightOracle.sol +1 -98
- package/contracts/examples/flight/FlightOracleAuthorization.sol +2 -3
- package/contracts/examples/flight/FlightProduct.sol +2 -2
- package/contracts/examples/flight/FlightProductAuthorization.sol +1 -1
- package/contracts/instance/BundleSet.sol +7 -8
- package/contracts/instance/IInstance.sol +10 -7
- package/contracts/instance/IInstanceService.sol +11 -6
- 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 +18 -1
- package/contracts/instance/InstanceService.sol +65 -37
- package/contracts/instance/InstanceStore.sol +14 -14
- package/contracts/instance/ProductStore.sol +14 -14
- 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/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 +2 -2
- 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 -5
- package/contracts/product/PolicyService.sol +1 -1
- package/contracts/product/RiskService.sol +2 -2
- package/contracts/registry/ChainNft.sol +1 -1
- package/contracts/registry/IRegistry.sol +3 -3
- package/contracts/registry/Registry.sol +5 -3
- 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 -2
- package/contracts/staking/StakingStore.sol +3 -3
- package/contracts/staking/TargetHandler.sol +2 -2
- package/contracts/type/RequestId.sol +6 -0
- package/contracts/upgradeability/ProxyManager.sol +2 -2
- package/package.json +3 -3
@@ -0,0 +1,495 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
|
+
|
6
|
+
import {IAuthorization} from "../../authorization/IAuthorization.sol";
|
7
|
+
import {IComponents} from "../../instance/module/IComponents.sol";
|
8
|
+
import {IPolicy} from "../../instance/module/IPolicy.sol";
|
9
|
+
|
10
|
+
import {Amount, AmountLib} from "../../type/Amount.sol";
|
11
|
+
import {ClaimId} from "../../type/ClaimId.sol";
|
12
|
+
import {FeeLib} from "../../type/Fee.sol";
|
13
|
+
import {InstanceReader} from "../../instance/InstanceReader.sol";
|
14
|
+
import {Location, LocationLib} from "./Location.sol";
|
15
|
+
import {NftId, NftIdLib} from "../../type/NftId.sol";
|
16
|
+
import {PayoutId} from "../../type/PayoutId.sol";
|
17
|
+
import {Product} from "../../product/Product.sol";
|
18
|
+
import {ReferralLib} from "../../type/Referral.sol";
|
19
|
+
import {RiskId} from "../../type/RiskId.sol";
|
20
|
+
import {RequestId} from "../../type/RequestId.sol";
|
21
|
+
import {Seconds, SecondsLib} from "../../type/Seconds.sol";
|
22
|
+
import {Str} from "../../type/String.sol";
|
23
|
+
import {Timestamp, TimestampLib} from "../../type/Timestamp.sol";
|
24
|
+
import {UFixed, UFixedLib} from "../../type/UFixed.sol";
|
25
|
+
|
26
|
+
|
27
|
+
/// @dev CropProduct implements the crop insurance product.
|
28
|
+
contract CropProduct is
|
29
|
+
Product
|
30
|
+
{
|
31
|
+
|
32
|
+
// Custom errors
|
33
|
+
error ErrorInvalidId(string id);
|
34
|
+
error ErrorRecordAlreadyExists(string id);
|
35
|
+
|
36
|
+
error ErrorInvalidYear(uint16 year);
|
37
|
+
error ErrorInvalidSeasonStart(string seasonStart);
|
38
|
+
error ErrorInvalidSeasonEnd(string seasonEnd);
|
39
|
+
error ErrorInvalidSeasonDays(uint16 seasonDays);
|
40
|
+
|
41
|
+
error ErrorInvalidSeasonEndAt(Timestamp seasonEndAt);
|
42
|
+
|
43
|
+
error ErrorInvalidSeasonId(string seasonId);
|
44
|
+
error ErrorInvalidLocation(string locationId);
|
45
|
+
error ErrorInvalidCrop(string crop);
|
46
|
+
|
47
|
+
error ErrorInvalidPolicyHolder();
|
48
|
+
error ErrorInvalidRiskId(RiskId riskId);
|
49
|
+
error ErrorInvalidActivateAt(Timestamp activateAt);
|
50
|
+
error ErrorInvalidSumInsured(Amount sumInsuredAmount);
|
51
|
+
error ErrorInvalidPremium(Amount premiumAmount);
|
52
|
+
|
53
|
+
error ErrorUndefinedRiskPayout(RiskId riskId);
|
54
|
+
|
55
|
+
// solhint-disable var-name-mixedcase
|
56
|
+
Amount public MIN_PREMIUM;
|
57
|
+
Amount public MAX_PREMIUM;
|
58
|
+
Amount public MIN_SUM_INSURED;
|
59
|
+
Amount public MAX_SUM_INSURED;
|
60
|
+
uint8 public MAX_POLICIES_TO_PROCESS = 1;
|
61
|
+
// solhint-enable var-name-mixedcase
|
62
|
+
|
63
|
+
// Crop insurance specifics
|
64
|
+
uint16 public constant GRACE_PERIOD_DAYS = 60;
|
65
|
+
|
66
|
+
struct Season {
|
67
|
+
uint16 year;
|
68
|
+
Str name;
|
69
|
+
Str seasonStart; // ISO 8601 date
|
70
|
+
Str seasonEnd; // ISO 8601 date
|
71
|
+
uint16 seasonDays;
|
72
|
+
}
|
73
|
+
|
74
|
+
struct CropRisk {
|
75
|
+
Str seasonId;
|
76
|
+
Str locationId;
|
77
|
+
Str crop;
|
78
|
+
Timestamp seasonEndAt;
|
79
|
+
UFixed payoutFactor;
|
80
|
+
bool payoutDefined;
|
81
|
+
}
|
82
|
+
|
83
|
+
// Seasons
|
84
|
+
mapping (Str seasonId => Season season) internal _season;
|
85
|
+
Str [] internal _seasons;
|
86
|
+
|
87
|
+
// Locations
|
88
|
+
mapping(Str locationId => Location location) internal _location;
|
89
|
+
|
90
|
+
// Crop names
|
91
|
+
mapping(Str cropName => bool isValid) internal _validCrop;
|
92
|
+
Str [] internal _crops;
|
93
|
+
|
94
|
+
mapping(Str id => RiskId riskId) internal _riskId;
|
95
|
+
mapping(RiskId riskId => RequestId requestId) internal _requests;
|
96
|
+
|
97
|
+
// GIF V3 specifics
|
98
|
+
NftId internal _defaultBundleNftId;
|
99
|
+
|
100
|
+
|
101
|
+
constructor(
|
102
|
+
address registry,
|
103
|
+
NftId instanceNftId,
|
104
|
+
string memory componentName,
|
105
|
+
IAuthorization authorization
|
106
|
+
)
|
107
|
+
{
|
108
|
+
address initialOwner = msg.sender;
|
109
|
+
|
110
|
+
_initialize(
|
111
|
+
registry,
|
112
|
+
instanceNftId,
|
113
|
+
componentName,
|
114
|
+
authorization,
|
115
|
+
initialOwner);
|
116
|
+
}
|
117
|
+
|
118
|
+
|
119
|
+
//--- external risk relatee functions -----------------------------------//
|
120
|
+
|
121
|
+
function createSeason(
|
122
|
+
Str seasonId,
|
123
|
+
uint16 year,
|
124
|
+
Str name,
|
125
|
+
Str seasonStart, // ISO 8601 date, eg "2025-02-18"
|
126
|
+
Str seasonEnd,
|
127
|
+
uint16 seasonDays
|
128
|
+
)
|
129
|
+
external
|
130
|
+
restricted()
|
131
|
+
{
|
132
|
+
// validate input
|
133
|
+
if (seasonId.length() == 0) { revert ErrorInvalidId(seasonId.toString()); }
|
134
|
+
if (_season[seasonId].year > 0) { revert ErrorRecordAlreadyExists(seasonId.toString()); }
|
135
|
+
if (year < 2023 || year > 2035 ) { revert ErrorInvalidYear(year); }
|
136
|
+
if (seasonStart.length() != 10 ) { revert ErrorInvalidSeasonStart(seasonStart.toString()); }
|
137
|
+
if (seasonEnd.length() != 10 ) { revert ErrorInvalidSeasonEnd(seasonEnd.toString()); }
|
138
|
+
if (seasonDays < 50 || seasonDays > 250 ) { revert ErrorInvalidSeasonDays(seasonDays); }
|
139
|
+
|
140
|
+
_seasons.push(seasonId);
|
141
|
+
_season[seasonId] = Season({
|
142
|
+
year: year,
|
143
|
+
name: name,
|
144
|
+
seasonStart: seasonStart,
|
145
|
+
seasonEnd: seasonEnd,
|
146
|
+
seasonDays: seasonDays
|
147
|
+
});
|
148
|
+
}
|
149
|
+
|
150
|
+
function createLocation(
|
151
|
+
Str locationId,
|
152
|
+
int32 latitude,
|
153
|
+
int32 longitude
|
154
|
+
)
|
155
|
+
external
|
156
|
+
restricted()
|
157
|
+
returns (Location location)
|
158
|
+
{
|
159
|
+
// validate input
|
160
|
+
if (locationId.length() == 0) { revert ErrorInvalidId(locationId.toString()); }
|
161
|
+
// TODO add function location.isUndefined()
|
162
|
+
// if (!_location[locationId].isUndefined()) { revert ErrorRecordAlreadyExists(locationId.toString()); }
|
163
|
+
|
164
|
+
location = LocationLib.toLocation(latitude, longitude);
|
165
|
+
_location[locationId] = location;
|
166
|
+
}
|
167
|
+
|
168
|
+
function createCrop(Str cropName) external restricted() {
|
169
|
+
if (cropName.length() == 0) { revert ErrorInvalidId(cropName.toString()); }
|
170
|
+
if (_validCrop[cropName]) { revert ErrorRecordAlreadyExists(cropName.toString()); }
|
171
|
+
|
172
|
+
_crops.push(cropName);
|
173
|
+
_validCrop[cropName] = true;
|
174
|
+
}
|
175
|
+
|
176
|
+
function createRisk(
|
177
|
+
Str id,
|
178
|
+
Str seasonId,
|
179
|
+
Str locationId,
|
180
|
+
Str crop,
|
181
|
+
Timestamp seasonEndAt
|
182
|
+
)
|
183
|
+
external
|
184
|
+
restricted()
|
185
|
+
returns (RiskId riskId)
|
186
|
+
{
|
187
|
+
// validate input
|
188
|
+
if (id.length() == 0) { revert ErrorInvalidId(id.toString()); }
|
189
|
+
if (_season[seasonId].year == 0) { revert ErrorInvalidSeasonId(seasonId.toString()); }
|
190
|
+
// TODO add function location.isUndefined()
|
191
|
+
// if (_locations[locationId].isUndefined()) { revert ErrorInvalidLocation(locationId.toString()); }
|
192
|
+
if (!_validCrop[crop]) { revert ErrorInvalidCrop(crop.toString()); }
|
193
|
+
if (seasonEndAt < TimestampLib.current()) { revert ErrorInvalidSeasonEndAt(seasonEndAt); }
|
194
|
+
|
195
|
+
// create risk, if new
|
196
|
+
bytes32 riskKey = keccak256(abi.encode(id));
|
197
|
+
CropRisk memory cropRisk = CropRisk({
|
198
|
+
seasonId: seasonId,
|
199
|
+
locationId: locationId,
|
200
|
+
crop: crop,
|
201
|
+
seasonEndAt: seasonEndAt,
|
202
|
+
payoutFactor: UFixedLib.zero(),
|
203
|
+
payoutDefined: false
|
204
|
+
});
|
205
|
+
|
206
|
+
riskId = _createRisk(riskKey, abi.encode(cropRisk));
|
207
|
+
_riskId[id] = riskId;
|
208
|
+
}
|
209
|
+
|
210
|
+
|
211
|
+
function updatePayoutFactor(
|
212
|
+
RiskId riskId,
|
213
|
+
UFixed payoutFactor
|
214
|
+
)
|
215
|
+
external
|
216
|
+
restricted()
|
217
|
+
{
|
218
|
+
(bool exists, CropRisk memory cropRisk) = getRisk(riskId);
|
219
|
+
if (!exists) { revert ErrorInvalidRiskId(riskId); }
|
220
|
+
|
221
|
+
cropRisk.payoutFactor = payoutFactor;
|
222
|
+
cropRisk.payoutDefined = true;
|
223
|
+
|
224
|
+
_updateRisk(riskId, abi.encode(cropRisk));
|
225
|
+
}
|
226
|
+
|
227
|
+
//--- external policy related functions ---------------------------------//
|
228
|
+
|
229
|
+
/// @dev Creates a policy.
|
230
|
+
function createPolicy(
|
231
|
+
address policyHolder,
|
232
|
+
RiskId riskId,
|
233
|
+
Timestamp activateAt,
|
234
|
+
Amount sumInsuredAmount,
|
235
|
+
Amount premiumAmount
|
236
|
+
)
|
237
|
+
external
|
238
|
+
virtual
|
239
|
+
restricted()
|
240
|
+
returns (NftId policyNftId)
|
241
|
+
{
|
242
|
+
// validate input
|
243
|
+
if (policyHolder == address(0)) { revert ErrorInvalidPolicyHolder(); }
|
244
|
+
|
245
|
+
(bool exists, CropRisk memory cropRisk) = getRisk(riskId);
|
246
|
+
if (!exists) { revert ErrorInvalidRiskId(riskId); }
|
247
|
+
|
248
|
+
if (activateAt < TimestampLib.current()) { revert ErrorInvalidActivateAt(activateAt); }
|
249
|
+
if (activateAt > cropRisk.seasonEndAt) { revert ErrorInvalidActivateAt(activateAt); }
|
250
|
+
if (sumInsuredAmount < MIN_SUM_INSURED || sumInsuredAmount > MAX_SUM_INSURED) { revert ErrorInvalidSumInsured(sumInsuredAmount); }
|
251
|
+
if (premiumAmount < MIN_PREMIUM || premiumAmount > MAX_PREMIUM) { revert ErrorInvalidPremium(premiumAmount); }
|
252
|
+
|
253
|
+
// calculate policy lifetime
|
254
|
+
uint96 seasonDays = _season[cropRisk.seasonId].seasonDays;
|
255
|
+
Seconds lifetime = SecondsLib.toSeconds((seasonDays + GRACE_PERIOD_DAYS) * 24 * 3600);
|
256
|
+
|
257
|
+
// create application
|
258
|
+
policyNftId = _createApplication(
|
259
|
+
policyHolder,
|
260
|
+
riskId,
|
261
|
+
sumInsuredAmount,
|
262
|
+
premiumAmount,
|
263
|
+
lifetime,
|
264
|
+
_defaultBundleNftId,
|
265
|
+
ReferralLib.zero(),
|
266
|
+
abi.encode(premiumAmount)); // application data: premium amount, see calculateNetPremium
|
267
|
+
|
268
|
+
// underwrite and activate policy
|
269
|
+
_createPolicy(
|
270
|
+
policyNftId,
|
271
|
+
activateAt,
|
272
|
+
premiumAmount); // max premium amount
|
273
|
+
|
274
|
+
_collectPremium(
|
275
|
+
policyNftId,
|
276
|
+
TimestampLib.zero()); // keep activation timestamp
|
277
|
+
}
|
278
|
+
|
279
|
+
|
280
|
+
function processPolicy(NftId policyNftId)
|
281
|
+
external
|
282
|
+
restricted()
|
283
|
+
{
|
284
|
+
_processPolicy(policyNftId);
|
285
|
+
}
|
286
|
+
|
287
|
+
function processPoliciesForRisk(
|
288
|
+
RiskId riskId,
|
289
|
+
uint256 maxPoliciesToProcess
|
290
|
+
)
|
291
|
+
external
|
292
|
+
virtual
|
293
|
+
returns (
|
294
|
+
bool success,
|
295
|
+
bool riskExists,
|
296
|
+
bool payoutDefined,
|
297
|
+
uint256 policiesProcessed
|
298
|
+
)
|
299
|
+
{
|
300
|
+
// determine numbers of policies to process
|
301
|
+
CropRisk memory cropRisk;
|
302
|
+
(riskExists, cropRisk) = getRisk(riskId);
|
303
|
+
|
304
|
+
// return if risk does not exist or payout is not defined yet
|
305
|
+
if (!riskExists) { return (false, false, false, 0); }
|
306
|
+
if (!cropRisk.payoutDefined) { return (false, true, false, 0); }
|
307
|
+
|
308
|
+
InstanceReader reader = _getInstanceReader();
|
309
|
+
uint256 policiesToProcess = reader.policiesForRisk(riskId);
|
310
|
+
policiesProcessed = policiesToProcess < maxPoliciesToProcess ? policiesToProcess : maxPoliciesToProcess;
|
311
|
+
|
312
|
+
// go through policies
|
313
|
+
for (uint256 i = 0; i < policiesProcessed; i++) {
|
314
|
+
NftId policyNftId = reader.getPolicyForRisk(riskId, i);
|
315
|
+
_processPolicy(policyNftId);
|
316
|
+
}
|
317
|
+
|
318
|
+
return (true, true, true, policiesProcessed);
|
319
|
+
}
|
320
|
+
|
321
|
+
|
322
|
+
//--- owner functions ---------------------------------------------------//
|
323
|
+
|
324
|
+
/// @dev Call after product registration with the instance
|
325
|
+
/// when the product token/tokenhandler is available
|
326
|
+
function setConstants(
|
327
|
+
Amount minPremium,
|
328
|
+
Amount maxPremium,
|
329
|
+
Amount minSumInsured,
|
330
|
+
Amount maxSumInsured,
|
331
|
+
uint8 maxPoliciesToProcess
|
332
|
+
)
|
333
|
+
external
|
334
|
+
virtual
|
335
|
+
restricted()
|
336
|
+
onlyOwner()
|
337
|
+
{
|
338
|
+
MIN_PREMIUM = minPremium;
|
339
|
+
MAX_PREMIUM = maxPremium;
|
340
|
+
MIN_SUM_INSURED = minSumInsured;
|
341
|
+
MAX_SUM_INSURED = maxSumInsured;
|
342
|
+
MAX_POLICIES_TO_PROCESS = maxPoliciesToProcess;
|
343
|
+
}
|
344
|
+
|
345
|
+
function setDefaultBundle(NftId bundleNftId) external restricted() onlyOwner() { _defaultBundleNftId = bundleNftId; }
|
346
|
+
|
347
|
+
function approveTokenHandler(IERC20Metadata token, Amount amount) external restricted() onlyOwner() { _approveTokenHandler(token, amount); }
|
348
|
+
function setLocked(bool locked) external onlyOwner() { _setLocked(locked); }
|
349
|
+
function setWallet(address newWallet) external restricted() onlyOwner() { _setWallet(newWallet); }
|
350
|
+
|
351
|
+
//--- unpermissioned functions ------------------------------------------//
|
352
|
+
|
353
|
+
//--- view functions ----------------------------------------------------//
|
354
|
+
|
355
|
+
function getSeason(Str seasonId) public view returns (Season memory season) { return _season[seasonId]; }
|
356
|
+
function getLocation(Str locationId) public view returns (Location location) { return _location[locationId]; }
|
357
|
+
|
358
|
+
function seasons() public view returns (Str [] memory) { return _seasons; }
|
359
|
+
function crops() public view returns (Str [] memory) { return _crops; }
|
360
|
+
|
361
|
+
function getRisk(RiskId riskId)
|
362
|
+
public
|
363
|
+
view
|
364
|
+
returns (
|
365
|
+
bool exists,
|
366
|
+
CropRisk memory cropRisk
|
367
|
+
)
|
368
|
+
{
|
369
|
+
// check if risk exists
|
370
|
+
InstanceReader reader = _getInstanceReader();
|
371
|
+
exists = reader.isProductRisk(getNftId(), riskId);
|
372
|
+
|
373
|
+
// get risk data if risk exists
|
374
|
+
if (exists) {
|
375
|
+
cropRisk = abi.decode(
|
376
|
+
reader.getRiskInfo(riskId).data,
|
377
|
+
(CropRisk));
|
378
|
+
}
|
379
|
+
}
|
380
|
+
|
381
|
+
function calculateNetPremium(
|
382
|
+
Amount, // sumInsuredAmount: not used in this product
|
383
|
+
RiskId, // riskId: not used in this product
|
384
|
+
Seconds, // lifetime: not used in this product, a flight is a one time risk
|
385
|
+
bytes memory applicationData // holds the premium amount the customer is willing to pay
|
386
|
+
)
|
387
|
+
external
|
388
|
+
virtual override
|
389
|
+
view
|
390
|
+
returns (Amount netPremiumAmount)
|
391
|
+
{
|
392
|
+
(netPremiumAmount) = abi.decode(applicationData, (Amount));
|
393
|
+
}
|
394
|
+
|
395
|
+
|
396
|
+
function calculatePayout(
|
397
|
+
IPolicy.PolicyInfo memory info,
|
398
|
+
CropRisk memory cropRisk
|
399
|
+
)
|
400
|
+
public
|
401
|
+
pure
|
402
|
+
returns (Amount payoutAmount)
|
403
|
+
{
|
404
|
+
Amount sumInsuredAmount = info.sumInsuredAmount;
|
405
|
+
UFixed payoutFactor = cropRisk.payoutFactor;
|
406
|
+
|
407
|
+
if (payoutFactor.eqz()) {
|
408
|
+
return AmountLib.zero();
|
409
|
+
}
|
410
|
+
|
411
|
+
return sumInsuredAmount.multiplyWith(payoutFactor);
|
412
|
+
}
|
413
|
+
|
414
|
+
function getRequestForRisk(RiskId riskId) public view returns (RequestId requestId) { return _requests[riskId]; }
|
415
|
+
|
416
|
+
//--- internal functions ------------------------------------------------//
|
417
|
+
|
418
|
+
|
419
|
+
function _processPolicy(NftId policyNftId)
|
420
|
+
internal
|
421
|
+
virtual
|
422
|
+
{
|
423
|
+
IPolicy.PolicyInfo memory info = _getInstanceReader().getPolicyInfo(policyNftId);
|
424
|
+
(bool exists, CropRisk memory cropRisk) = getRisk(info.riskId);
|
425
|
+
if (!exists) { revert ErrorInvalidRiskId(info.riskId); }
|
426
|
+
if (!cropRisk.payoutDefined) { revert ErrorUndefinedRiskPayout(info.riskId); }
|
427
|
+
|
428
|
+
// create claim/payout (if applicable), then expire and close policy
|
429
|
+
_handlePayout(policyNftId, info, cropRisk);
|
430
|
+
_expire(policyNftId, TimestampLib.current());
|
431
|
+
_close(policyNftId);
|
432
|
+
}
|
433
|
+
|
434
|
+
|
435
|
+
function _handlePayout(
|
436
|
+
NftId policyNftId,
|
437
|
+
IPolicy.PolicyInfo memory info,
|
438
|
+
CropRisk memory cropRisk
|
439
|
+
)
|
440
|
+
internal
|
441
|
+
{
|
442
|
+
Amount payoutAmount = calculatePayout(info, cropRisk);
|
443
|
+
|
444
|
+
// if payout amount > 0: create and process claim and payout
|
445
|
+
if (payoutAmount.eqz()) {
|
446
|
+
return;
|
447
|
+
}
|
448
|
+
|
449
|
+
// create confirmed claim
|
450
|
+
ClaimId claimId = _submitClaim(policyNftId, payoutAmount, "");
|
451
|
+
_confirmClaim(policyNftId, claimId, payoutAmount, "");
|
452
|
+
|
453
|
+
// create and execute payout
|
454
|
+
PayoutId payoutId = _createPayout(policyNftId, claimId, payoutAmount, "");
|
455
|
+
_processPayout(policyNftId, payoutId);
|
456
|
+
}
|
457
|
+
|
458
|
+
|
459
|
+
function _initialize(
|
460
|
+
address registry,
|
461
|
+
NftId instanceNftId,
|
462
|
+
string memory componentName,
|
463
|
+
IAuthorization authorization,
|
464
|
+
address initialOwner
|
465
|
+
)
|
466
|
+
internal
|
467
|
+
initializer()
|
468
|
+
{
|
469
|
+
__Product_init(
|
470
|
+
registry,
|
471
|
+
instanceNftId,
|
472
|
+
componentName,
|
473
|
+
IComponents.ProductInfo({
|
474
|
+
isProcessingFundedClaims: false,
|
475
|
+
isInterceptingPolicyTransfers: false,
|
476
|
+
hasDistribution: false,
|
477
|
+
expectedNumberOfOracles: 0,
|
478
|
+
numberOfOracles: 0,
|
479
|
+
poolNftId: NftIdLib.zero(),
|
480
|
+
distributionNftId: NftIdLib.zero(),
|
481
|
+
oracleNftId: new NftId[](0)
|
482
|
+
}),
|
483
|
+
IComponents.FeeInfo({
|
484
|
+
productFee: FeeLib.zero(),
|
485
|
+
processingFee: FeeLib.zero(),
|
486
|
+
distributionFee: FeeLib.zero(),
|
487
|
+
minDistributionOwnerFee: FeeLib.zero(),
|
488
|
+
poolFee: FeeLib.zero(),
|
489
|
+
stakingFee: FeeLib.zero(),
|
490
|
+
performanceFee: FeeLib.zero()
|
491
|
+
}),
|
492
|
+
authorization,
|
493
|
+
initialOwner);
|
494
|
+
}
|
495
|
+
}
|
@@ -0,0 +1,69 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IAccess} from "../../../contracts/authorization/IAccess.sol";
|
5
|
+
|
6
|
+
import {AccessAdminLib} from "../../authorization/AccessAdminLib.sol";
|
7
|
+
import {BasicProductAuthorization} from "../../product/BasicProductAuthorization.sol";
|
8
|
+
import {CropProduct} from "./CropProduct.sol";
|
9
|
+
import {RoleId, ADMIN_ROLE, PUBLIC_ROLE} from "../../../contracts/type/RoleId.sol";
|
10
|
+
|
11
|
+
|
12
|
+
contract CropProductAuthorization
|
13
|
+
is BasicProductAuthorization
|
14
|
+
{
|
15
|
+
|
16
|
+
uint64 public constant PRODUCT_OPERATOR_ROLE_IDX = 1; // 1st custom role for flight product
|
17
|
+
string public constant PRODUCT_OPERATOR_ROLE_NAME = "ProductOperatorRole";
|
18
|
+
// solhint-disable-next-line var-name-mixedcase
|
19
|
+
RoleId public PRODUCT_OPERATOR_ROLE;
|
20
|
+
|
21
|
+
|
22
|
+
constructor(string memory productName)
|
23
|
+
BasicProductAuthorization(productName)
|
24
|
+
{ }
|
25
|
+
|
26
|
+
|
27
|
+
function _setupRoles()
|
28
|
+
internal
|
29
|
+
override
|
30
|
+
{
|
31
|
+
PRODUCT_OPERATOR_ROLE = AccessAdminLib.getCustomRoleId(PRODUCT_OPERATOR_ROLE_IDX);
|
32
|
+
|
33
|
+
_addRole(
|
34
|
+
PRODUCT_OPERATOR_ROLE,
|
35
|
+
AccessAdminLib.roleInfo(
|
36
|
+
ADMIN_ROLE(),
|
37
|
+
TargetType.Custom,
|
38
|
+
100, // max member count
|
39
|
+
PRODUCT_OPERATOR_ROLE_NAME));
|
40
|
+
}
|
41
|
+
|
42
|
+
|
43
|
+
function _setupTargetAuthorizations()
|
44
|
+
internal
|
45
|
+
virtual override
|
46
|
+
{
|
47
|
+
super._setupTargetAuthorizations();
|
48
|
+
IAccess.FunctionInfo[] storage functions;
|
49
|
+
|
50
|
+
// authorize product operator role
|
51
|
+
functions = _authorizeForTarget(getMainTargetName(), PRODUCT_OPERATOR_ROLE);
|
52
|
+
_authorize(functions, CropProduct.createSeason.selector, "createSeason");
|
53
|
+
_authorize(functions, CropProduct.createLocation.selector, "createLocation");
|
54
|
+
_authorize(functions, CropProduct.createCrop.selector, "createCrop");
|
55
|
+
_authorize(functions, CropProduct.createRisk.selector, "createRisk");
|
56
|
+
_authorize(functions, CropProduct.createPolicy.selector, "createPolicy");
|
57
|
+
_authorize(functions, CropProduct.updatePayoutFactor.selector, "updatePayoutFactor");
|
58
|
+
_authorize(functions, CropProduct.processPolicy.selector, "processPolicy");
|
59
|
+
|
60
|
+
// authorize public role (additional authz via onlyOwner)
|
61
|
+
functions = _authorizeForTarget(getMainTargetName(), PUBLIC_ROLE());
|
62
|
+
_authorize(functions, CropProduct.setDefaultBundle.selector, "setDefaultBundle");
|
63
|
+
_authorize(functions, CropProduct.setConstants.selector, "setConstants");
|
64
|
+
_authorize(functions, CropProduct.approveTokenHandler.selector, "approveTokenHandler");
|
65
|
+
_authorize(functions, CropProduct.setLocked.selector, "setLocked");
|
66
|
+
_authorize(functions, CropProduct.setWallet.selector, "setWallet");
|
67
|
+
}
|
68
|
+
}
|
69
|
+
|
@@ -0,0 +1,50 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
type Location is uint64;
|
5
|
+
|
6
|
+
using {
|
7
|
+
LocationLib.latitude,
|
8
|
+
LocationLib.longitude
|
9
|
+
} for Location global;
|
10
|
+
|
11
|
+
library LocationLib {
|
12
|
+
|
13
|
+
error ErrorLatitudeInvalid(int32 amount);
|
14
|
+
error ErrorLongitudeInvalid(int32 amount);
|
15
|
+
|
16
|
+
int32 public constant LATITUDE_MIN = -90000000;
|
17
|
+
int32 public constant LATITUDE_MAX = 90000000;
|
18
|
+
int32 public constant LONGITUDE_MIN = -180000000;
|
19
|
+
int32 public constant LONGITUDE_MAX = 180000000;
|
20
|
+
|
21
|
+
// Constants for bit manipulation
|
22
|
+
int64 public constant LATITUDE_MASK = int64(0x7FFFFFF);
|
23
|
+
int64 public constant LONGITUDE_MASK = int64(0xFFFFFFF);
|
24
|
+
|
25
|
+
function zero() public pure returns (Location) {
|
26
|
+
return Location.wrap(0);
|
27
|
+
}
|
28
|
+
|
29
|
+
function toLocation(int32 latitude, int32 longitude) public pure returns (Location) {
|
30
|
+
if (latitude < LATITUDE_MIN || latitude > LATITUDE_MAX) revert ErrorLatitudeInvalid(latitude);
|
31
|
+
if (longitude < LONGITUDE_MIN || longitude > LONGITUDE_MAX) revert ErrorLongitudeInvalid(longitude);
|
32
|
+
|
33
|
+
uint32 latPacked = uint32(latitude);
|
34
|
+
uint32 longPacked = uint32(longitude);
|
35
|
+
// uint64 packed = (uint64(latPacked) << 32) | uint64(longPacked);
|
36
|
+
return Location.wrap((uint64(latPacked) << 32) | uint64(longPacked));
|
37
|
+
}
|
38
|
+
|
39
|
+
function latitude(Location location) public pure returns (int32) {
|
40
|
+
return int32(uint32(Location.unwrap(location) >> 32));
|
41
|
+
}
|
42
|
+
|
43
|
+
function longitude(Location location) public pure returns (int32) {
|
44
|
+
return int32(uint32(Location.unwrap(location) & 0xFFFFFFFF));
|
45
|
+
}
|
46
|
+
|
47
|
+
function decimals() public pure returns (uint8) {
|
48
|
+
return uint8(6);
|
49
|
+
}
|
50
|
+
}
|