@etherisc/gif-next 0.0.2-ffba655 → 3.0.0-1a7e54a-113
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +277 -68
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1075 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +810 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +843 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +1735 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +2008 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +1403 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +817 -0
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +4 -0
- package/artifacts/contracts/{instance/access → authorization}/IAccess.sol/IAccess.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +1400 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +465 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +407 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +4 -0
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +652 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +1234 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +844 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +4 -0
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +939 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +1809 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +4 -0
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +950 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +838 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +4 -0
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +1284 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1474 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2043 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +844 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +500 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +229 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1198 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +849 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +1466 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +2189 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +844 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +376 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +901 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1429 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +844 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1161 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1637 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2575 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +844 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.json +332 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +851 -0
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +304 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +734 -451
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +1102 -0
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +810 -530
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +2400 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +872 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +2628 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +1348 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +792 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +3039 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +3427 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +866 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.json +137 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +223 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +192 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +4 -0
- package/artifacts/contracts/instance/{pool/IPoolModule.sol/IPool.json → module/IBundle.sol/IBundle.json} +2 -2
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/{component/IComponent.sol/IComponent.json → module/IComponents.sol/IComponents.json} +2 -2
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.json +10 -0
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +4 -0
- package/artifacts/contracts/instance/{policy → module}/IPolicy.sol/IPolicy.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.json +10 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +947 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +849 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +52 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +762 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +762 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +863 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +1042 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +830 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +1232 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +844 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +1438 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +886 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +1033 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +895 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +1449 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +4 -0
- package/artifacts/contracts/pool/Pool.sol/Pool.json +1015 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +1833 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +886 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +1036 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +810 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +1149 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +844 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +1536 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +906 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +804 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +1104 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +1036 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +652 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +4 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +1006 -0
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +665 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +1404 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +874 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +932 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +834 -0
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +4 -0
- package/artifacts/contracts/product/Product.sol/Product.json +1107 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +873 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +794 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +295 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +1055 -113
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +1072 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/{instance/component/IComponent.sol/IInstanceLinked.json → registry/IRelease.sol/IRelease.json} +6 -6
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +4 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +39 -0
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +1543 -176
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +2255 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1137 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +1298 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +793 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2271 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +205 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1401 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +705 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +4 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +721 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/shared/Component.sol/Component.json +695 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +1551 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +882 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +632 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol/IOwnable.json → shared/ContractLib.sol/IInstanceAdminHelper.json} +5 -5
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/{instance/access/IAccess.sol/IAccessCheckRole.json → shared/ContractLib.sol/ITargetHelper.json} +4 -9
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +620 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +1175 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +697 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +146 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol/IRegisterable.json → shared/INftOwnable.sol/INftOwnable.json} +72 -72
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +175 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +4 -0
- package/artifacts/contracts/{instance/component/ComponentModule.sol/ComponentModule.json → shared/IRegisterable.sol/IRegisterable.json} +179 -158
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{registry/IRegistry.sol → shared/IRegistryLinked.sol}/IRegistryLinked.json +5 -19
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +4 -0
- package/artifacts/contracts/shared/IService.sol/IService.json +428 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +785 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +174 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +4 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +228 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +198 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +4 -0
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +397 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +58 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +4 -0
- package/artifacts/contracts/shared/Service.sol/Service.json +482 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +723 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +4 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +2747 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +1147 -0
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +4 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.json +3175 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +470 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +867 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +704 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +1344 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +786 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +3097 -0
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +679 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +4 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +10 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +398 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +4 -0
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +270 -0
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +203 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +104 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +4 -0
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +373 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +4 -0
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +125 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +228 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +33 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +4 -0
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +238 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +209 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +4 -0
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +161 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +33 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +204 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +254 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +308 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +148 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +4 -0
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +10 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +105 -0
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +4 -0
- package/artifacts/contracts/type/String.sol/StrLib.json +199 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +4 -0
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +344 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +4 -0
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +572 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionLib.json +158 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +4 -0
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +167 -0
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +65 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +672 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +142 -0
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +88 -0
- package/contracts/accounting/AccountingService.sol +274 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +47 -0
- package/contracts/authorization/AccessAdmin.sol +679 -0
- package/contracts/authorization/AccessAdminLib.sol +678 -0
- package/contracts/authorization/AccessManagerCloneable.sol +140 -0
- package/contracts/authorization/Authorization.sol +190 -0
- package/contracts/authorization/IAccess.sol +66 -0
- package/contracts/authorization/IAccessAdmin.sol +142 -0
- package/contracts/authorization/IAuthorization.sol +26 -0
- package/contracts/authorization/IServiceAuthorization.sol +78 -0
- package/contracts/authorization/ServiceAuthorization.sol +300 -0
- package/contracts/distribution/BasicDistribution.sol +140 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +67 -0
- package/contracts/distribution/Distribution.sol +245 -0
- package/contracts/distribution/DistributionService.sol +448 -0
- package/contracts/distribution/DistributionServiceManager.sol +39 -0
- package/contracts/distribution/IDistributionComponent.sol +45 -0
- package/contracts/distribution/IDistributionService.sol +115 -0
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +433 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/flight/FlightLib.sol +311 -0
- package/contracts/examples/flight/FlightMessageVerifier.sol +128 -0
- package/contracts/examples/flight/FlightOracle.sol +167 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +34 -0
- package/contracts/examples/flight/FlightPool.sol +89 -0
- package/contracts/examples/flight/FlightPoolAuthorization.sol +37 -0
- package/contracts/examples/flight/FlightProduct.sol +545 -0
- package/contracts/examples/flight/FlightProductAuthorization.sol +44 -0
- package/contracts/examples/flight/FlightUSD.sol +26 -0
- package/contracts/examples/flight/originalV1.sol +396 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +437 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BaseStore.sol +93 -0
- package/contracts/instance/BundleSet.sol +130 -0
- package/contracts/instance/IBaseStore.sol +37 -0
- package/contracts/instance/IInstance.sol +151 -15
- package/contracts/instance/IInstanceService.sol +119 -0
- package/contracts/instance/Instance.sol +332 -45
- package/contracts/instance/InstanceAdmin.sol +307 -0
- package/contracts/instance/InstanceAuthorizationV3.sol +275 -0
- package/contracts/instance/InstanceReader.sol +628 -0
- package/contracts/instance/InstanceService.sol +514 -0
- package/contracts/instance/InstanceServiceManager.sol +39 -0
- package/contracts/instance/InstanceStore.sol +323 -0
- package/contracts/instance/ProductStore.sol +290 -0
- package/contracts/instance/RiskSet.sol +126 -0
- package/contracts/instance/TargetNames.sol +10 -0
- package/contracts/instance/base/BalanceStore.sol +121 -0
- package/contracts/instance/base/Cloneable.sol +28 -0
- package/contracts/instance/base/ObjectCounter.sol +20 -0
- package/contracts/instance/base/ObjectLifecycle.sol +109 -0
- package/contracts/instance/base/ObjectSet.sol +77 -0
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +21 -0
- package/contracts/instance/module/IComponents.sol +60 -0
- package/contracts/instance/module/IDistribution.sol +54 -0
- package/contracts/instance/module/IPolicy.sol +105 -0
- package/contracts/instance/module/IRisk.sol +16 -0
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/BasicOracle.sol +44 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +53 -0
- package/contracts/oracle/IOracle.sol +41 -0
- package/contracts/oracle/IOracleComponent.sol +33 -0
- package/contracts/oracle/IOracleService.sol +66 -0
- package/contracts/oracle/Oracle.sol +152 -0
- package/contracts/oracle/OracleService.sol +310 -0
- package/contracts/oracle/OracleServiceManager.sol +39 -0
- package/contracts/pool/BasicPool.sol +161 -0
- package/contracts/pool/BasicPoolAuthorization.sol +81 -0
- package/contracts/pool/BundleService.sol +386 -0
- package/contracts/pool/BundleServiceManager.sol +39 -0
- package/contracts/pool/IBundleService.sol +116 -0
- package/contracts/pool/IPoolComponent.sol +62 -0
- package/contracts/pool/IPoolService.sol +170 -0
- package/contracts/pool/Pool.sol +331 -0
- package/contracts/pool/PoolLib.sol +341 -0
- package/contracts/pool/PoolService.sol +614 -0
- package/contracts/pool/PoolServiceManager.sol +39 -0
- package/contracts/product/ApplicationService.sol +327 -0
- package/contracts/product/ApplicationServiceManager.sol +38 -0
- package/contracts/product/BasicProduct.sol +48 -0
- package/contracts/product/BasicProductAuthorization.sol +64 -0
- package/contracts/product/ClaimService.sol +626 -0
- package/contracts/product/ClaimServiceManager.sol +38 -0
- package/contracts/product/IApplicationService.sol +88 -0
- package/contracts/product/IClaimService.sol +136 -0
- package/contracts/product/IPolicyService.sol +102 -0
- package/contracts/product/IPricingService.sol +40 -0
- package/contracts/product/IProductComponent.sol +62 -0
- package/contracts/product/IRiskService.sol +48 -0
- package/contracts/product/PolicyService.sol +645 -0
- package/contracts/product/PolicyServiceLib.sol +139 -0
- package/contracts/product/PolicyServiceManager.sol +39 -0
- package/contracts/product/PricingService.sol +306 -0
- package/contracts/product/PricingServiceManager.sol +39 -0
- package/contracts/product/Product.sol +491 -0
- package/contracts/product/RiskService.sol +189 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +176 -100
- package/contracts/registry/IRegistry.sol +149 -47
- package/contracts/registry/IRegistryService.sol +62 -0
- package/contracts/registry/IRelease.sol +29 -0
- package/contracts/registry/ITransferInterceptor.sol +6 -0
- package/contracts/registry/Registry.sol +671 -117
- package/contracts/registry/RegistryAdmin.sol +173 -0
- package/contracts/registry/RegistryAuthorization.sol +337 -0
- package/contracts/registry/RegistryService.sol +241 -0
- package/contracts/registry/RegistryServiceManager.sol +53 -0
- package/contracts/registry/ReleaseAdmin.sol +199 -0
- package/contracts/registry/ReleaseLifecycle.sol +32 -0
- package/contracts/registry/ReleaseRegistry.sol +525 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +342 -0
- package/contracts/registry/TokenRegistry.sol +317 -0
- package/contracts/shared/Component.sol +210 -0
- package/contracts/shared/ComponentService.sol +691 -0
- package/contracts/shared/ComponentServiceManager.sol +38 -0
- package/contracts/shared/ContractLib.sol +312 -0
- package/contracts/shared/EcdsaChecker.sol +5 -0
- package/contracts/shared/IComponent.sol +58 -0
- package/contracts/shared/IComponentService.sol +111 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +30 -0
- package/contracts/shared/ILifecycle.sol +31 -0
- package/contracts/shared/INftOwnable.sol +27 -0
- package/contracts/shared/IPolicyHolder.sol +35 -0
- package/contracts/shared/IRegisterable.sol +36 -0
- package/contracts/shared/IRegistryLinked.sol +11 -0
- package/contracts/shared/IService.sol +23 -0
- package/contracts/shared/InitializableERC165.sol +35 -0
- package/contracts/shared/InstanceLinkedComponent.sol +232 -0
- package/contracts/shared/Lifecycle.sol +88 -0
- package/contracts/shared/NftIdSet.sol +65 -0
- package/contracts/shared/NftOwnable.sol +129 -0
- package/contracts/shared/PolicyHolder.sol +63 -0
- package/contracts/shared/Registerable.sol +106 -0
- package/contracts/shared/RegistryLinked.sol +38 -0
- package/contracts/shared/Service.sol +67 -0
- package/contracts/shared/TokenHandler.sol +342 -0
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +366 -0
- package/contracts/staking/IStakingService.sol +127 -0
- package/contracts/staking/ITargetLimitHandler.sol +17 -0
- package/contracts/staking/Staking.sol +797 -0
- package/contracts/staking/StakingLib.sol +195 -0
- package/contracts/staking/StakingManager.sol +53 -0
- package/contracts/staking/StakingReader.sol +171 -0
- package/contracts/staking/StakingService.sol +321 -0
- package/contracts/staking/StakingServiceManager.sol +46 -0
- package/contracts/staking/StakingStore.sol +1368 -0
- package/contracts/staking/TargetHandler.sol +132 -0
- package/contracts/staking/TargetManagerLib.sol +234 -0
- package/contracts/type/AddressSet.sol +58 -0
- package/contracts/type/Amount.sol +154 -0
- package/contracts/type/Blocknumber.sol +137 -0
- package/contracts/type/ChainId.sol +101 -0
- package/contracts/type/ClaimId.sol +80 -0
- package/contracts/type/DistributorType.sol +55 -0
- package/contracts/type/Fee.sol +66 -0
- package/contracts/type/Key32.sol +50 -0
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +85 -0
- package/contracts/type/NftIdSet.sol +62 -0
- package/contracts/type/ObjectType.sol +278 -0
- package/contracts/type/PayoutId.sol +82 -0
- package/contracts/type/Referral.sol +96 -0
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RequestIdSet.sol +62 -0
- package/contracts/type/RiskId.sol +75 -0
- package/contracts/type/RoleId.sol +180 -0
- package/contracts/type/Seconds.sol +124 -0
- package/contracts/type/Selector.sol +107 -0
- package/contracts/type/StateId.sol +149 -0
- package/contracts/type/String.sol +95 -0
- package/contracts/type/Timestamp.sol +152 -0
- package/contracts/type/UFixed.sol +263 -0
- package/contracts/type/Version.sol +159 -0
- package/contracts/upgradeability/IVersionable.sol +56 -0
- package/contracts/upgradeability/ProxyManager.sol +246 -0
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +24 -0
- package/contracts/upgradeability/Versionable.sol +62 -0
- package/package.json +27 -7
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/Component.json +0 -179
- package/artifacts/contracts/components/Component.sol/InstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/components/Component.sol/InstanceLinked.json +0 -35
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IPool.sol/IPoolComponent.json +0 -179
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IProduct.sol/IProductComponent.json +0 -192
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +0 -4
- package/artifacts/contracts/components/Pool.sol/Pool.json +0 -213
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +0 -4
- package/artifacts/contracts/components/Product.sol/Product.json +0 -231
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.json +0 -50
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/Access.sol/AccessModule.json +0 -400
- package/artifacts/contracts/instance/access/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessCheckRole.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessComponentTypeRoles.json +0 -50
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.dbg.json +0 -4
- package/artifacts/contracts/instance/access/IAccess.sol/IAccessModule.json +0 -336
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/ComponentModule.sol/ComponentOwnerService.json +0 -147
- package/artifacts/contracts/instance/component/IComponent.sol/IComponent.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentContract.json +0 -179
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentModule.json +0 -245
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/component/IComponent.sol/IComponentOwnerService.json +0 -94
- package/artifacts/contracts/instance/component/IComponent.sol/IInstanceLinked.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicy.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/IPolicy.sol/IPolicyModule.json +0 -231
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.dbg.json +0 -4
- package/artifacts/contracts/instance/policy/PolicyModule.sol/PolicyModule.json +0 -231
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPool.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/IPoolModule.sol/IPoolModule.json +0 -149
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.dbg.json +0 -4
- package/artifacts/contracts/instance/pool/PoolModule.sol/PoolModule.json +0 -162
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductModule.json +0 -75
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/IProductService.sol/IProductService.json +0 -114
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductModule.json +0 -75
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/instance/product/ProductService.sol/ProductService.json +0 -167
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.dbg.json +0 -4
- package/artifacts/contracts/registry/IChainNft.sol/IChainNft.json +0 -452
- package/artifacts/contracts/registry/IRegistry.sol/IOwnable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegisterable.dbg.json +0 -4
- package/artifacts/contracts/registry/IRegistry.sol/IRegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/Registerable.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/Registerable.json +0 -166
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.dbg.json +0 -4
- package/artifacts/contracts/registry/Registry.sol/RegistryLinked.json +0 -60
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +0 -4
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +0 -174
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.json +0 -10
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +0 -4
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +0 -92
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +0 -4
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +0 -174
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.dbg.json +0 -4
- package/artifacts/contracts/types/UFixed.sol/UFixedMathLib.json +0 -453
- package/contracts/components/Component.sol +0 -62
- package/contracts/components/IPool.sol +0 -9
- package/contracts/components/IProduct.sol +0 -12
- package/contracts/components/Pool.sol +0 -29
- package/contracts/components/Product.sol +0 -66
- package/contracts/experiment/errors/Require.sol +0 -33
- package/contracts/experiment/errors/Revert.sol +0 -39
- package/contracts/experiment/inheritance/A.sol +0 -56
- package/contracts/experiment/inheritance/B.sol +0 -23
- package/contracts/experiment/inheritance/C.sol +0 -28
- package/contracts/experiment/inheritance/IA.sol +0 -18
- package/contracts/experiment/inheritance/IB.sol +0 -9
- package/contracts/experiment/inheritance/IC.sol +0 -11
- package/contracts/experiment/types/TypeA.sol +0 -42
- package/contracts/experiment/types/TypeB.sol +0 -24
- package/contracts/instance/access/Access.sol +0 -218
- package/contracts/instance/access/IAccess.sol +0 -83
- package/contracts/instance/component/ComponentModule.sol +0 -248
- package/contracts/instance/component/IComponent.sol +0 -95
- package/contracts/instance/policy/IPolicy.sol +0 -66
- package/contracts/instance/policy/PolicyModule.sol +0 -107
- package/contracts/instance/pool/IPoolModule.sol +0 -41
- package/contracts/instance/pool/PoolModule.sol +0 -86
- package/contracts/instance/product/IProductService.sol +0 -46
- package/contracts/instance/product/ProductService.sol +0 -108
- package/contracts/registry/IChainNft.sol +0 -18
- package/contracts/types/Blocknumber.sol +0 -60
- package/contracts/types/ChainId.sol +0 -30
- package/contracts/types/NftId.sol +0 -35
- package/contracts/types/Timestamp.sol +0 -55
- package/contracts/types/UFixed.sol +0 -211
| @@ -0,0 +1,152 @@ | |
| 1 | 
            +
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 | 
            +
            pragma solidity ^0.8.20;
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            import {Seconds} from "./Seconds.sol";
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            /// @dev Target: Cover 10 years with 1 ms block time resolution.
         | 
| 7 | 
            +
            /// Typical block time resolution is 1s.
         | 
| 8 | 
            +
            type Timestamp is uint40;
         | 
| 9 | 
            +
             | 
| 10 | 
            +
            using {
         | 
| 11 | 
            +
                gtTimestamp as >,
         | 
| 12 | 
            +
                gteTimestamp as >=,
         | 
| 13 | 
            +
                ltTimestamp as <,
         | 
| 14 | 
            +
                lteTimestamp as <=,
         | 
| 15 | 
            +
                eqTimestamp as ==,
         | 
| 16 | 
            +
                neTimestamp as !=,
         | 
| 17 | 
            +
                TimestampLib.eq,
         | 
| 18 | 
            +
                TimestampLib.ne,
         | 
| 19 | 
            +
                TimestampLib.gt,
         | 
| 20 | 
            +
                TimestampLib.gte,
         | 
| 21 | 
            +
                TimestampLib.lt,
         | 
| 22 | 
            +
                TimestampLib.lte,
         | 
| 23 | 
            +
                TimestampLib.gtz,
         | 
| 24 | 
            +
                TimestampLib.eqz,
         | 
| 25 | 
            +
                TimestampLib.addSeconds,
         | 
| 26 | 
            +
                TimestampLib.subtractSeconds,
         | 
| 27 | 
            +
                TimestampLib.toInt
         | 
| 28 | 
            +
            } for Timestamp global;
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            /// @dev return true if Timestamp a is after Timestamp b
         | 
| 31 | 
            +
            function gtTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 32 | 
            +
                return Timestamp.unwrap(a) > Timestamp.unwrap(b);
         | 
| 33 | 
            +
            }
         | 
| 34 | 
            +
             | 
| 35 | 
            +
            /// @dev return true if Timestamp a is after or equal to Timestamp b
         | 
| 36 | 
            +
            function gteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 37 | 
            +
                return Timestamp.unwrap(a) >= Timestamp.unwrap(b);
         | 
| 38 | 
            +
            }
         | 
| 39 | 
            +
             | 
| 40 | 
            +
            /// @dev return true if Timestamp a is before Timestamp b
         | 
| 41 | 
            +
            function ltTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 42 | 
            +
                return Timestamp.unwrap(a) < Timestamp.unwrap(b);
         | 
| 43 | 
            +
            }
         | 
| 44 | 
            +
             | 
| 45 | 
            +
            /// @dev return true if Timestamp a is before or equal to Timestamp b
         | 
| 46 | 
            +
            function lteTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 47 | 
            +
                return Timestamp.unwrap(a) <= Timestamp.unwrap(b);
         | 
| 48 | 
            +
            }
         | 
| 49 | 
            +
             | 
| 50 | 
            +
            /// @dev return true if Timestamp a is equal to Timestamp b
         | 
| 51 | 
            +
            function eqTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 52 | 
            +
                return Timestamp.unwrap(a) == Timestamp.unwrap(b);
         | 
| 53 | 
            +
            }
         | 
| 54 | 
            +
             | 
| 55 | 
            +
            /// @dev return true if Timestamp a is not equal to Timestamp b
         | 
| 56 | 
            +
            function neTimestamp(Timestamp a, Timestamp b) pure returns (bool) {
         | 
| 57 | 
            +
                return Timestamp.unwrap(a) != Timestamp.unwrap(b);
         | 
| 58 | 
            +
            }
         | 
| 59 | 
            +
             | 
| 60 | 
            +
            // TODO move to TimestampLib and rename to zero()
         | 
| 61 | 
            +
            /// @dev Return the Timestamp zero (0)
         | 
| 62 | 
            +
            function zeroTimestamp() pure returns (Timestamp) {
         | 
| 63 | 
            +
                return Timestamp.wrap(0);
         | 
| 64 | 
            +
            }
         | 
| 65 | 
            +
             | 
| 66 | 
            +
            library TimestampLib {
         | 
| 67 | 
            +
             | 
| 68 | 
            +
                function zero() public pure returns (Timestamp) {
         | 
| 69 | 
            +
                    return Timestamp.wrap(0);
         | 
| 70 | 
            +
                }
         | 
| 71 | 
            +
             | 
| 72 | 
            +
                function max() public pure returns (Timestamp) {
         | 
| 73 | 
            +
                    return Timestamp.wrap(type(uint40).max);
         | 
| 74 | 
            +
                }
         | 
| 75 | 
            +
             | 
| 76 | 
            +
                function current() public view returns (Timestamp) {
         | 
| 77 | 
            +
                    return Timestamp.wrap(uint40(block.timestamp));
         | 
| 78 | 
            +
                }
         | 
| 79 | 
            +
             | 
| 80 | 
            +
                function toTimestamp(uint256 timestamp) public pure returns (Timestamp) {
         | 
| 81 | 
            +
                    return Timestamp.wrap(uint40(timestamp));
         | 
| 82 | 
            +
                }
         | 
| 83 | 
            +
                
         | 
| 84 | 
            +
                /// @dev return true if Timestamp a is after Timestamp b
         | 
| 85 | 
            +
                function gt(Timestamp a, Timestamp b) public pure returns (bool isAfter) {
         | 
| 86 | 
            +
                    return gtTimestamp(a, b);
         | 
| 87 | 
            +
                }
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                /// @dev return true if Timestamp a is after or the same than Timestamp b
         | 
| 90 | 
            +
                function gte(
         | 
| 91 | 
            +
                    Timestamp a,
         | 
| 92 | 
            +
                    Timestamp b
         | 
| 93 | 
            +
                ) public pure returns (bool isAfterOrSame) {
         | 
| 94 | 
            +
                    return gteTimestamp(a, b);
         | 
| 95 | 
            +
                }
         | 
| 96 | 
            +
             | 
| 97 | 
            +
                /// @dev return true if Timestamp a is before Timestamp b
         | 
| 98 | 
            +
                function lt(Timestamp a, Timestamp b) public pure returns (bool isBefore) {
         | 
| 99 | 
            +
                    return ltTimestamp(a, b);
         | 
| 100 | 
            +
                }
         | 
| 101 | 
            +
             | 
| 102 | 
            +
                /// @dev return true if Timestamp a is before or the same than Timestamp b
         | 
| 103 | 
            +
                function lte(
         | 
| 104 | 
            +
                    Timestamp a,
         | 
| 105 | 
            +
                    Timestamp b
         | 
| 106 | 
            +
                ) public pure returns (bool isBeforeOrSame) {
         | 
| 107 | 
            +
                    return lteTimestamp(a, b);
         | 
| 108 | 
            +
                }
         | 
| 109 | 
            +
             | 
| 110 | 
            +
                /// @dev return true if Timestamp a is equal to Timestamp b
         | 
| 111 | 
            +
                function eq(Timestamp a, Timestamp b) public pure returns (bool isSame) {
         | 
| 112 | 
            +
                    return eqTimestamp(a, b);
         | 
| 113 | 
            +
                }
         | 
| 114 | 
            +
             | 
| 115 | 
            +
                /// @dev return true if Timestamp a is not equal to Timestamp b
         | 
| 116 | 
            +
                function ne(
         | 
| 117 | 
            +
                    Timestamp a,
         | 
| 118 | 
            +
                    Timestamp b
         | 
| 119 | 
            +
                ) public pure returns (bool isDifferent) {
         | 
| 120 | 
            +
                    return neTimestamp(a, b);
         | 
| 121 | 
            +
                }
         | 
| 122 | 
            +
             | 
| 123 | 
            +
                /// @dev return true if Timestamp equals 0
         | 
| 124 | 
            +
                function eqz(Timestamp timestamp) public pure returns (bool) {
         | 
| 125 | 
            +
                    return Timestamp.unwrap(timestamp) == 0;
         | 
| 126 | 
            +
                }
         | 
| 127 | 
            +
             | 
| 128 | 
            +
                /// @dev return true if Timestamp is larger than 0
         | 
| 129 | 
            +
                function gtz(Timestamp timestamp) public pure returns (bool) {
         | 
| 130 | 
            +
                    return Timestamp.unwrap(timestamp) > 0;
         | 
| 131 | 
            +
                }
         | 
| 132 | 
            +
             | 
| 133 | 
            +
                /// @dev return a new timestamp that is duration seconds later than the provided timestamp.
         | 
| 134 | 
            +
                function addSeconds(
         | 
| 135 | 
            +
                    Timestamp timestamp,
         | 
| 136 | 
            +
                    Seconds duration
         | 
| 137 | 
            +
                ) public pure returns (Timestamp) {
         | 
| 138 | 
            +
                    return toTimestamp(Timestamp.unwrap(timestamp) + duration.toInt());
         | 
| 139 | 
            +
                }
         | 
| 140 | 
            +
             | 
| 141 | 
            +
                /// @dev return a new timestamp that is duration seconds earlier than the provided timestamp.
         | 
| 142 | 
            +
                function subtractSeconds(
         | 
| 143 | 
            +
                    Timestamp timestamp,
         | 
| 144 | 
            +
                    Seconds duration
         | 
| 145 | 
            +
                ) public pure returns (Timestamp) {
         | 
| 146 | 
            +
                    return toTimestamp(Timestamp.unwrap(timestamp) - duration.toInt());
         | 
| 147 | 
            +
                }
         | 
| 148 | 
            +
             | 
| 149 | 
            +
                function toInt(Timestamp timestamp) public pure returns (uint256) {
         | 
| 150 | 
            +
                    return uint256(uint40(Timestamp.unwrap(timestamp)));
         | 
| 151 | 
            +
                }
         | 
| 152 | 
            +
            }
         | 
| @@ -0,0 +1,263 @@ | |
| 1 | 
            +
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 | 
            +
            pragma solidity ^0.8.20;
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            import {Math} from "@openzeppelin/contracts/utils/math/Math.sol";
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            /// @dev UFixed is a 160-bit fixed point number with 15 decimals precision.
         | 
| 7 | 
            +
            type UFixed is uint160; 
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            using {
         | 
| 10 | 
            +
                addUFixed as +,
         | 
| 11 | 
            +
                subUFixed as -,
         | 
| 12 | 
            +
                mulUFixed as *,
         | 
| 13 | 
            +
                divUFixed as /,
         | 
| 14 | 
            +
                gtUFixed as >,
         | 
| 15 | 
            +
                gteUFixed as >=,
         | 
| 16 | 
            +
                ltUFixed as <,
         | 
| 17 | 
            +
                lteUFixed as <=,
         | 
| 18 | 
            +
                eqUFixed as ==,
         | 
| 19 | 
            +
                neUFixed as !=,
         | 
| 20 | 
            +
                UFixedLib.gt,
         | 
| 21 | 
            +
                UFixedLib.eqz,
         | 
| 22 | 
            +
                UFixedLib.gtz,
         | 
| 23 | 
            +
                UFixedLib.toInt,
         | 
| 24 | 
            +
                UFixedLib.toInt1000
         | 
| 25 | 
            +
            } for UFixed global;
         | 
| 26 | 
            +
             | 
| 27 | 
            +
            // TODO move to UFixedLib and rename to zero()
         | 
| 28 | 
            +
            function zeroUFixed() pure returns (UFixed zero) {
         | 
| 29 | 
            +
                return UFixed.wrap(0);
         | 
| 30 | 
            +
            }
         | 
| 31 | 
            +
             | 
| 32 | 
            +
            function addUFixed(UFixed a, UFixed b) pure returns (UFixed) {
         | 
| 33 | 
            +
                return UFixed.wrap(UFixed.unwrap(a) + UFixed.unwrap(b));
         | 
| 34 | 
            +
            }
         | 
| 35 | 
            +
             | 
| 36 | 
            +
            function subUFixed(UFixed a, UFixed b) pure returns (UFixed) {
         | 
| 37 | 
            +
                if (a < b) {
         | 
| 38 | 
            +
                    revert UFixedLib.UFixedLibNegativeResult();
         | 
| 39 | 
            +
                }
         | 
| 40 | 
            +
                return UFixed.wrap(UFixed.unwrap(a) - UFixed.unwrap(b));
         | 
| 41 | 
            +
            }
         | 
| 42 | 
            +
             | 
| 43 | 
            +
            function mulUFixed(UFixed a, UFixed b) pure returns (UFixed) {
         | 
| 44 | 
            +
                return
         | 
| 45 | 
            +
                    UFixed.wrap(uint160(Math.mulDiv(UFixed.unwrap(a), UFixed.unwrap(b), 10 ** 15)));
         | 
| 46 | 
            +
            }
         | 
| 47 | 
            +
             | 
| 48 | 
            +
            function divUFixed(UFixed a, UFixed b) pure returns (UFixed) {
         | 
| 49 | 
            +
                if (UFixed.unwrap(b) == 0) {
         | 
| 50 | 
            +
                    revert UFixedLib.UFixedLibDivisionByZero();
         | 
| 51 | 
            +
                }
         | 
| 52 | 
            +
                
         | 
| 53 | 
            +
                return
         | 
| 54 | 
            +
                    UFixed.wrap(uint160(Math.mulDiv(UFixed.unwrap(a), 10 ** 15, UFixed.unwrap(b))));
         | 
| 55 | 
            +
            }
         | 
| 56 | 
            +
             | 
| 57 | 
            +
            function gtUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
         | 
| 58 | 
            +
                return UFixed.unwrap(a) > UFixed.unwrap(b);
         | 
| 59 | 
            +
            }
         | 
| 60 | 
            +
             | 
| 61 | 
            +
            function gteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
         | 
| 62 | 
            +
                return UFixed.unwrap(a) >= UFixed.unwrap(b);
         | 
| 63 | 
            +
            }
         | 
| 64 | 
            +
             | 
| 65 | 
            +
            function ltUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
         | 
| 66 | 
            +
                return UFixed.unwrap(a) < UFixed.unwrap(b);
         | 
| 67 | 
            +
            }
         | 
| 68 | 
            +
             | 
| 69 | 
            +
            function lteUFixed(UFixed a, UFixed b) pure returns (bool isGreaterThan) {
         | 
| 70 | 
            +
                return UFixed.unwrap(a) <= UFixed.unwrap(b);
         | 
| 71 | 
            +
            }
         | 
| 72 | 
            +
             | 
| 73 | 
            +
            function eqUFixed(UFixed a, UFixed b) pure returns (bool isEqual) {
         | 
| 74 | 
            +
                return UFixed.unwrap(a) == UFixed.unwrap(b);
         | 
| 75 | 
            +
            }
         | 
| 76 | 
            +
             | 
| 77 | 
            +
            function neUFixed(UFixed a, UFixed b) pure returns (bool isEqual) {
         | 
| 78 | 
            +
                return UFixed.unwrap(a) != UFixed.unwrap(b);
         | 
| 79 | 
            +
            }
         | 
| 80 | 
            +
             | 
| 81 | 
            +
            function gtzUFixed(UFixed a) pure returns (bool isZero) {
         | 
| 82 | 
            +
                return UFixed.unwrap(a) > 0;
         | 
| 83 | 
            +
            }
         | 
| 84 | 
            +
             | 
| 85 | 
            +
            function eqzUFixed(UFixed a) pure returns (bool isZero) {
         | 
| 86 | 
            +
                return UFixed.unwrap(a) == 0;
         | 
| 87 | 
            +
            }
         | 
| 88 | 
            +
             | 
| 89 | 
            +
            function deltaUFixed(UFixed a, UFixed b) pure returns (UFixed) {
         | 
| 90 | 
            +
                if (a > b) {
         | 
| 91 | 
            +
                    return a - b;
         | 
| 92 | 
            +
                }
         | 
| 93 | 
            +
             | 
| 94 | 
            +
                return b - a;
         | 
| 95 | 
            +
            }
         | 
| 96 | 
            +
             | 
| 97 | 
            +
            library UFixedLib {
         | 
| 98 | 
            +
                error UFixedLibNegativeResult();
         | 
| 99 | 
            +
                error UFixedLibDivisionByZero();
         | 
| 100 | 
            +
             | 
| 101 | 
            +
                error UFixedLibExponentTooSmall(int8 exp);
         | 
| 102 | 
            +
                error UFixedLibExponentTooLarge(int8 exp);
         | 
| 103 | 
            +
             | 
| 104 | 
            +
                error UFixedLibNumberTooLarge(uint256 number);
         | 
| 105 | 
            +
             | 
| 106 | 
            +
                int8 public constant EXP = 15;
         | 
| 107 | 
            +
                uint256 public constant MULTIPLIER = 10 ** uint256(int256(EXP));
         | 
| 108 | 
            +
                uint256 public constant MULTIPLIER_HALF = MULTIPLIER / 2;
         | 
| 109 | 
            +
             | 
| 110 | 
            +
                /// @dev returns the rounding mode DOWN - 0.4 becomes 0, 0.5 becomes 0, 0.6 becomes 0
         | 
| 111 | 
            +
                function ROUNDING_DOWN() public pure returns (uint8) {
         | 
| 112 | 
            +
                    return uint8(0);
         | 
| 113 | 
            +
                }
         | 
| 114 | 
            +
             | 
| 115 | 
            +
                /// @dev returns the rounding mode UP - 0.4 becomes 1, 0.5 becomes 1, 0.6 becomes 1
         | 
| 116 | 
            +
                function ROUNDING_UP() public pure returns (uint8) {
         | 
| 117 | 
            +
                    return uint8(1);
         | 
| 118 | 
            +
                }
         | 
| 119 | 
            +
             | 
| 120 | 
            +
                /// @dev returns the rounding mode HALF_UP - 0.4 becomes 0, 0.5 becomes 1, 0.6 becomes 1
         | 
| 121 | 
            +
                function ROUNDING_HALF_UP() public pure returns (uint8) {
         | 
| 122 | 
            +
                    return uint8(2);
         | 
| 123 | 
            +
                }
         | 
| 124 | 
            +
             | 
| 125 | 
            +
                /// @dev Converts the uint256 to a uint160 based UFixed. 
         | 
| 126 | 
            +
                /// This method reverts if the number is too large to fit in a uint160.
         | 
| 127 | 
            +
                function toUFixed(uint256 a) public pure returns (UFixed) {
         | 
| 128 | 
            +
                    uint256 n = a * MULTIPLIER;
         | 
| 129 | 
            +
                    if (n > type(uint160).max) {
         | 
| 130 | 
            +
                        revert UFixedLibNumberTooLarge(a);
         | 
| 131 | 
            +
                    }
         | 
| 132 | 
            +
                    return UFixed.wrap(uint160(n));
         | 
| 133 | 
            +
                }
         | 
| 134 | 
            +
             | 
| 135 | 
            +
                /// @dev Converts the uint256 to a UFixed with given exponent.
         | 
| 136 | 
            +
                function toUFixed(uint256 a, int8 exp) public pure returns (UFixed) {
         | 
| 137 | 
            +
                    if (EXP + exp < 0) {
         | 
| 138 | 
            +
                        revert UFixedLibExponentTooSmall(exp);
         | 
| 139 | 
            +
                    }
         | 
| 140 | 
            +
                    if (EXP + exp > 48) {
         | 
| 141 | 
            +
                        revert UFixedLibExponentTooLarge(exp);
         | 
| 142 | 
            +
                    }
         | 
| 143 | 
            +
                    
         | 
| 144 | 
            +
                    uint256 n = a * 10 ** uint8(EXP + exp);
         | 
| 145 | 
            +
             | 
| 146 | 
            +
                    if (n > type(uint160).max) {
         | 
| 147 | 
            +
                        revert UFixedLibNumberTooLarge(n);
         | 
| 148 | 
            +
                    }
         | 
| 149 | 
            +
             | 
| 150 | 
            +
                    return UFixed.wrap(uint160(n));
         | 
| 151 | 
            +
                }
         | 
| 152 | 
            +
             | 
| 153 | 
            +
                /// @dev returns the decimals precision of the UFixed type
         | 
| 154 | 
            +
                function decimals() public pure returns (uint256) {
         | 
| 155 | 
            +
                    return uint8(EXP);
         | 
| 156 | 
            +
                }
         | 
| 157 | 
            +
             | 
| 158 | 
            +
                /// @dev Converts a UFixed to a uint256.
         | 
| 159 | 
            +
                function toInt(UFixed a) public pure returns (uint256) {
         | 
| 160 | 
            +
                    return toIntWithRounding(a, ROUNDING_HALF_UP());
         | 
| 161 | 
            +
                }
         | 
| 162 | 
            +
             | 
| 163 | 
            +
                /// @dev Converts a UFixed to a uint256.
         | 
| 164 | 
            +
                function toInt1000(UFixed a) public pure returns (uint256) {
         | 
| 165 | 
            +
                    return toIntWithRounding(toUFixed(1000) * a, ROUNDING_HALF_UP());
         | 
| 166 | 
            +
                }
         | 
| 167 | 
            +
             | 
| 168 | 
            +
                /// @dev Converts a UFixed to a uint256 with given rounding mode.
         | 
| 169 | 
            +
                function toIntWithRounding(UFixed a, uint8 rounding) public pure returns (uint256) {
         | 
| 170 | 
            +
                    if (rounding == ROUNDING_HALF_UP()) {
         | 
| 171 | 
            +
                        return
         | 
| 172 | 
            +
                            Math.mulDiv(
         | 
| 173 | 
            +
                                UFixed.unwrap(a) + MULTIPLIER_HALF,
         | 
| 174 | 
            +
                                1,
         | 
| 175 | 
            +
                                MULTIPLIER,
         | 
| 176 | 
            +
                                Math.Rounding.Floor
         | 
| 177 | 
            +
                            );
         | 
| 178 | 
            +
                    } else if (rounding == ROUNDING_DOWN()) {
         | 
| 179 | 
            +
                        return
         | 
| 180 | 
            +
                            Math.mulDiv(
         | 
| 181 | 
            +
                                UFixed.unwrap(a),
         | 
| 182 | 
            +
                                1,
         | 
| 183 | 
            +
                                MULTIPLIER,
         | 
| 184 | 
            +
                                Math.Rounding.Floor
         | 
| 185 | 
            +
                            );
         | 
| 186 | 
            +
                    } else {
         | 
| 187 | 
            +
                        return
         | 
| 188 | 
            +
                            Math.mulDiv(UFixed.unwrap(a), 1, MULTIPLIER, Math.Rounding.Ceil);
         | 
| 189 | 
            +
                    }
         | 
| 190 | 
            +
                }
         | 
| 191 | 
            +
             | 
| 192 | 
            +
                /// @dev adds two UFixed numbers
         | 
| 193 | 
            +
                function add(UFixed a, UFixed b) public pure returns (UFixed) {
         | 
| 194 | 
            +
                    return addUFixed(a, b);
         | 
| 195 | 
            +
                }
         | 
| 196 | 
            +
             | 
| 197 | 
            +
                /// @dev subtracts two UFixed numbers
         | 
| 198 | 
            +
                function sub(UFixed a, UFixed b) public pure returns (UFixed) {
         | 
| 199 | 
            +
                    return subUFixed(a, b);
         | 
| 200 | 
            +
                }
         | 
| 201 | 
            +
             | 
| 202 | 
            +
                /// @dev multiplies two UFixed numbers
         | 
| 203 | 
            +
                function mul(UFixed a, UFixed b) public pure returns (UFixed) {
         | 
| 204 | 
            +
                    return mulUFixed(a, b);
         | 
| 205 | 
            +
                }
         | 
| 206 | 
            +
             | 
| 207 | 
            +
                /// @dev divides two UFixed numbers
         | 
| 208 | 
            +
                function div(UFixed a, UFixed b) public pure returns (UFixed) {
         | 
| 209 | 
            +
                    return divUFixed(a, b);
         | 
| 210 | 
            +
                }
         | 
| 211 | 
            +
             | 
| 212 | 
            +
                /// @dev return true if UFixed a is greater than UFixed b
         | 
| 213 | 
            +
                function gt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
         | 
| 214 | 
            +
                    return gtUFixed(a, b);
         | 
| 215 | 
            +
                }
         | 
| 216 | 
            +
             | 
| 217 | 
            +
                /// @dev return true if UFixed a is greater than or equal to UFixed b
         | 
| 218 | 
            +
                function gte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
         | 
| 219 | 
            +
                    return gteUFixed(a, b);
         | 
| 220 | 
            +
                }
         | 
| 221 | 
            +
             | 
| 222 | 
            +
                /// @dev return true if UFixed a is less than UFixed b
         | 
| 223 | 
            +
                function lt(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
         | 
| 224 | 
            +
                    return ltUFixed(a, b);
         | 
| 225 | 
            +
                }
         | 
| 226 | 
            +
             | 
| 227 | 
            +
                /// @dev return true if UFixed a is less than or equal to UFixed b
         | 
| 228 | 
            +
                function lte(UFixed a, UFixed b) public pure returns (bool isGreaterThan) {
         | 
| 229 | 
            +
                    return lteUFixed(a, b);
         | 
| 230 | 
            +
                }
         | 
| 231 | 
            +
             | 
| 232 | 
            +
                /// @dev return true if UFixed a is equal to UFixed b
         | 
| 233 | 
            +
                function eq(UFixed a, UFixed b) public pure returns (bool isEqual) {
         | 
| 234 | 
            +
                    return eqUFixed(a, b);
         | 
| 235 | 
            +
                }
         | 
| 236 | 
            +
             | 
| 237 | 
            +
                /// @dev return true if UFixed a is not zero
         | 
| 238 | 
            +
                function gtz(UFixed a) public pure returns (bool isZero) {
         | 
| 239 | 
            +
                    return gtzUFixed(a);
         | 
| 240 | 
            +
                }
         | 
| 241 | 
            +
             | 
| 242 | 
            +
                /// @dev return true if UFixed a is zero
         | 
| 243 | 
            +
                function eqz(UFixed a) public pure returns (bool isZero) {
         | 
| 244 | 
            +
                    return eqzUFixed(a);
         | 
| 245 | 
            +
                }
         | 
| 246 | 
            +
             | 
| 247 | 
            +
                function zero() public pure returns (UFixed) {
         | 
| 248 | 
            +
                    return UFixed.wrap(0);
         | 
| 249 | 
            +
                }
         | 
| 250 | 
            +
             | 
| 251 | 
            +
                function one() public pure returns (UFixed) {
         | 
| 252 | 
            +
                    return UFixed.wrap(uint160(MULTIPLIER));
         | 
| 253 | 
            +
                }
         | 
| 254 | 
            +
             | 
| 255 | 
            +
                function max() public pure returns (UFixed) {
         | 
| 256 | 
            +
                    return UFixed.wrap(type(uint160).max);
         | 
| 257 | 
            +
                }
         | 
| 258 | 
            +
             | 
| 259 | 
            +
                /// @dev return the absolute delta between two UFixed numbers
         | 
| 260 | 
            +
                function delta(UFixed a, UFixed b) public pure returns (UFixed) {
         | 
| 261 | 
            +
                    return deltaUFixed(a, b);
         | 
| 262 | 
            +
                }
         | 
| 263 | 
            +
            }
         | 
| @@ -0,0 +1,159 @@ | |
| 1 | 
            +
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 | 
            +
            pragma solidity ^0.8.20;
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            type VersionPart is uint8;
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            using {
         | 
| 7 | 
            +
                versionPartGt as >,
         | 
| 8 | 
            +
                versionPartEq as ==,
         | 
| 9 | 
            +
                versionPartNe as !=,
         | 
| 10 | 
            +
                VersionPartLib.eqz,
         | 
| 11 | 
            +
                VersionPartLib.gtz,
         | 
| 12 | 
            +
                VersionPartLib.toInt,
         | 
| 13 | 
            +
                VersionPartLib.toString,
         | 
| 14 | 
            +
                VersionPartLib.isValidRelease
         | 
| 15 | 
            +
            }
         | 
| 16 | 
            +
                for VersionPart global;
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            function versionPartGt(VersionPart a, VersionPart b) pure returns(bool isGreaterThan) { return VersionPart.unwrap(a) > VersionPart.unwrap(b); }
         | 
| 19 | 
            +
            function versionPartEq(VersionPart a, VersionPart b) pure returns(bool isSame) { return VersionPart.unwrap(a) == VersionPart.unwrap(b); }
         | 
| 20 | 
            +
            function versionPartNe(VersionPart a, VersionPart b) pure returns(bool isSame) { return VersionPart.unwrap(a) != VersionPart.unwrap(b); }
         | 
| 21 | 
            +
             | 
| 22 | 
            +
            library VersionPartLib {
         | 
| 23 | 
            +
             | 
| 24 | 
            +
                error ErrorReleaseTooBig(VersionPart releaseMax, VersionPart release);
         | 
| 25 | 
            +
             | 
| 26 | 
            +
                function releaseMin() public pure returns (VersionPart) { return toVersionPart(3); }
         | 
| 27 | 
            +
                function releaseMax() public pure returns (VersionPart) { return toVersionPart(99); }
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                function isValidRelease(VersionPart release) external pure returns(bool) { 
         | 
| 30 | 
            +
                    uint256 releaseInt = VersionPart.unwrap(release);
         | 
| 31 | 
            +
                    return 3 <= releaseInt && releaseInt <= 99; 
         | 
| 32 | 
            +
                } 
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                function toString(VersionPart a) external pure returns (string memory) {
         | 
| 35 | 
            +
                    if (a > releaseMax()) {
         | 
| 36 | 
            +
                        revert ErrorReleaseTooBig(releaseMax(), a);
         | 
| 37 | 
            +
                    }
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                    uint256 value = VersionPart.unwrap(a);
         | 
| 40 | 
            +
                    if (value == 0) {
         | 
| 41 | 
            +
                        return "0";
         | 
| 42 | 
            +
                    }
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                    uint256 temp = value;
         | 
| 45 | 
            +
                    uint256 digits = 0;
         | 
| 46 | 
            +
                    while (temp != 0) {
         | 
| 47 | 
            +
                        digits++;
         | 
| 48 | 
            +
                        temp /= 10;
         | 
| 49 | 
            +
                    }
         | 
| 50 | 
            +
             | 
| 51 | 
            +
                    bytes memory buffer = new bytes(digits);
         | 
| 52 | 
            +
                    uint index = digits - 1;
         | 
| 53 | 
            +
             | 
| 54 | 
            +
                    temp = value;
         | 
| 55 | 
            +
                    while (temp != 0) {
         | 
| 56 | 
            +
                        buffer[index] = bytes1(uint8(48 + temp % 10));
         | 
| 57 | 
            +
                        temp /= 10;
         | 
| 58 | 
            +
             | 
| 59 | 
            +
                        if (index > 0) {
         | 
| 60 | 
            +
                            index--;
         | 
| 61 | 
            +
                        }
         | 
| 62 | 
            +
                    }
         | 
| 63 | 
            +
             | 
| 64 | 
            +
                    return string(buffer);
         | 
| 65 | 
            +
                }
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                function eqz(VersionPart a) external pure returns(bool) { return VersionPart.unwrap(a) == 0; }
         | 
| 68 | 
            +
                function gtz(VersionPart a) external pure returns(bool) { return VersionPart.unwrap(a) > 0; }
         | 
| 69 | 
            +
                function toInt(VersionPart a) external pure returns(uint256) { return VersionPart.unwrap(a); }
         | 
| 70 | 
            +
                function toVersionPart(uint256 a) public pure returns(VersionPart) { return VersionPart.wrap(uint8(a)); }
         | 
| 71 | 
            +
            }
         | 
| 72 | 
            +
             | 
| 73 | 
            +
            type Version is uint24; // contains major,minor,patch version parts
         | 
| 74 | 
            +
             | 
| 75 | 
            +
            using {
         | 
| 76 | 
            +
                versionGt as >,
         | 
| 77 | 
            +
                versionEq as ==,
         | 
| 78 | 
            +
                VersionLib.toInt,
         | 
| 79 | 
            +
                VersionLib.toUint64,
         | 
| 80 | 
            +
                VersionLib.toMajorPart,
         | 
| 81 | 
            +
                VersionLib.toVersionParts
         | 
| 82 | 
            +
            }
         | 
| 83 | 
            +
                for Version global;
         | 
| 84 | 
            +
             | 
| 85 | 
            +
            function versionGt(Version a, Version b) pure returns(bool isGreaterThan) { return Version.unwrap(a) > Version.unwrap(b); }
         | 
| 86 | 
            +
            function versionEq(Version a, Version b) pure returns(bool isSame) { return Version.unwrap(a) == Version.unwrap(b); }
         | 
| 87 | 
            +
             | 
| 88 | 
            +
            library VersionLib {
         | 
| 89 | 
            +
             | 
| 90 | 
            +
                function toInt(Version version) external pure returns(uint) { return Version.unwrap(version); }
         | 
| 91 | 
            +
             | 
| 92 | 
            +
                function toUint64(Version version) external pure returns(uint64) { return Version.unwrap(version); }
         | 
| 93 | 
            +
             | 
| 94 | 
            +
                function toMajorPart(Version version)
         | 
| 95 | 
            +
                    external    
         | 
| 96 | 
            +
                    pure 
         | 
| 97 | 
            +
                    returns(VersionPart major)
         | 
| 98 | 
            +
                { 
         | 
| 99 | 
            +
                    uint24 versionInt = Version.unwrap(version);
         | 
| 100 | 
            +
                    uint8 majorInt = uint8(versionInt >> 16);
         | 
| 101 | 
            +
                    return VersionPart.wrap(majorInt);
         | 
| 102 | 
            +
                }
         | 
| 103 | 
            +
             | 
| 104 | 
            +
                function toVersionParts(Version version)
         | 
| 105 | 
            +
                    external
         | 
| 106 | 
            +
                    pure
         | 
| 107 | 
            +
                    returns(
         | 
| 108 | 
            +
                        VersionPart major,
         | 
| 109 | 
            +
                        VersionPart minor,
         | 
| 110 | 
            +
                        VersionPart patch
         | 
| 111 | 
            +
                    )
         | 
| 112 | 
            +
                {
         | 
| 113 | 
            +
                    uint24 versionInt = Version.unwrap(version);
         | 
| 114 | 
            +
                    uint8 majorInt = uint8(versionInt >> 16);
         | 
| 115 | 
            +
             | 
| 116 | 
            +
                    versionInt -= majorInt << 16;
         | 
| 117 | 
            +
                    uint8 minorInt = uint8(versionInt >> 8);
         | 
| 118 | 
            +
                    uint8 patchInt = uint8(versionInt - (minorInt << 8));
         | 
| 119 | 
            +
             | 
| 120 | 
            +
                    return (
         | 
| 121 | 
            +
                        VersionPart.wrap(majorInt),
         | 
| 122 | 
            +
                        VersionPart.wrap(minorInt),
         | 
| 123 | 
            +
                        VersionPart.wrap(patchInt)
         | 
| 124 | 
            +
                    );
         | 
| 125 | 
            +
                }
         | 
| 126 | 
            +
             | 
| 127 | 
            +
                // function toVersionPart(uint256 versionPart) public pure returns(VersionPart) { 
         | 
| 128 | 
            +
                //     return VersionPart.wrap(uint8(versionPart)); 
         | 
| 129 | 
            +
                // }
         | 
| 130 | 
            +
             | 
| 131 | 
            +
                function toVersion(
         | 
| 132 | 
            +
                    uint256 major,
         | 
| 133 | 
            +
                    uint256 minor,
         | 
| 134 | 
            +
                    uint256 patch
         | 
| 135 | 
            +
                )
         | 
| 136 | 
            +
                    external
         | 
| 137 | 
            +
                    pure
         | 
| 138 | 
            +
                    returns(Version)
         | 
| 139 | 
            +
                {
         | 
| 140 | 
            +
                    require(
         | 
| 141 | 
            +
                        major < 256 && minor < 256 && patch < 256,
         | 
| 142 | 
            +
                        "ERROR:VRS-010:VERSION_PART_TOO_BIG");
         | 
| 143 | 
            +
             | 
| 144 | 
            +
                    return Version.wrap(
         | 
| 145 | 
            +
                        uint24(
         | 
| 146 | 
            +
                            (major << 16) + (minor << 8) + patch));
         | 
| 147 | 
            +
                }
         | 
| 148 | 
            +
             | 
| 149 | 
            +
                // TODO check for overflow?
         | 
| 150 | 
            +
                function toVersion(uint64 versionNumber) external pure returns(Version) {
         | 
| 151 | 
            +
                    //assert(versionNumber <= type(Version).max);
         | 
| 152 | 
            +
                    return Version.wrap(uint24(versionNumber));
         | 
| 153 | 
            +
                }
         | 
| 154 | 
            +
             | 
| 155 | 
            +
                // TODO rename to zero()
         | 
| 156 | 
            +
                function zeroVersion() external pure returns(Version) {
         | 
| 157 | 
            +
                    return Version.wrap(0);
         | 
| 158 | 
            +
                }
         | 
| 159 | 
            +
            }
         | 
| @@ -0,0 +1,56 @@ | |
| 1 | 
            +
            // SPDX-License-Identifier: Apache-2.0
         | 
| 2 | 
            +
            pragma solidity ^0.8.20;
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            import {Version} from "../type/Version.sol";
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            /// IMPORTANT
         | 
| 7 | 
            +
            // Upgradeable contract MUST:
         | 
| 8 | 
            +
            // 1) inherit from Versionable
         | 
| 9 | 
            +
            // 2) implement version() function
         | 
| 10 | 
            +
            // 3) implement internal _initialize() function with onlyInitializing modifier 
         | 
| 11 | 
            +
            // 4) implement internal _upgrade() function with onlyInitializing modifier (1st version MUST revert)
         | 
| 12 | 
            +
            // 5) have onlyInitialising modifier for each function callable inside _initialize()/_upgrade() (MUST use different functions for initialization/upgrade and normal operations)
         | 
| 13 | 
            +
            // 6) use default empty constructor -> _disableInitializer() is called from Versionable contructor
         | 
| 14 | 
            +
            // 7) use namespace storage (should this be needed)
         | 
| 15 | 
            +
            // 8) since now inheritance is used for upgradability, contract MUST BE inherited ONLY by the next version 
         | 
| 16 | 
            +
            // Upgradeable contract SHOULD:
         | 
| 17 | 
            +
            // 9) define all non private methods as virtual (in order to be able to upgrade them latter)
         | 
| 18 | 
            +
            //    otherwise, it is still possible to upgrade contract, but everyone who is using it will have to switch to a new fucntions
         | 
| 19 | 
            +
            //    in some cases this ok but not in the others...
         | 
| 20 | 
            +
            //
         | 
| 21 | 
            +
            // IMPORTANT
         | 
| 22 | 
            +
            // If introducting/amending storage related to Versionable version MUST:
         | 
| 23 | 
            +
            // 1) define namespace storage struct if accessing storage
         | 
| 24 | 
            +
            //      - DO NOT use structs inside, except
         | 
| 25 | 
            +
            //      - CAN use structs ONLY inside mappings
         | 
| 26 | 
            +
            // 2) ALWAYS define private getter if accessing storage
         | 
| 27 | 
            +
            //      - MUST use default implementation, CAN change ONLY return type
         | 
| 28 | 
            +
             | 
| 29 | 
            +
            interface IVersionable {
         | 
| 30 | 
            +
             | 
| 31 | 
            +
                error ErrorVersionableInitializeNotImplemented();
         | 
| 32 | 
            +
                error ErrorVersionableUpgradeNotImplemented();
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                /**
         | 
| 35 | 
            +
                 * @dev IMPORTANT
         | 
| 36 | 
            +
                 * implementation MUST be guarded by initializer modifier
         | 
| 37 | 
            +
                 * new version MUST inherit from previous version
         | 
| 38 | 
            +
                 */
         | 
| 39 | 
            +
                function initializeVersionable(address activatedBy, bytes memory activationData) external;
         | 
| 40 | 
            +
             | 
| 41 | 
            +
                /**
         | 
| 42 | 
            +
                 * @dev
         | 
| 43 | 
            +
                 * implementation MUST be guarded by reinitializer(version().toUint64()) modifier
         | 
| 44 | 
            +
                 * new version MUST inherit from previous version
         | 
| 45 | 
            +
                 * the first verion MUST revert 
         | 
| 46 | 
            +
                 */
         | 
| 47 | 
            +
                function upgradeVersionable(bytes memory upgradeData) external;
         | 
| 48 | 
            +
             | 
| 49 | 
            +
                /**
         | 
| 50 | 
            +
                 * @dev returns version of this contract
         | 
| 51 | 
            +
                 * each new implementation MUST implement this function
         | 
| 52 | 
            +
                 * version number MUST increase 
         | 
| 53 | 
            +
                 */
         | 
| 54 | 
            +
                function getVersion() external pure returns(Version);
         | 
| 55 | 
            +
             | 
| 56 | 
            +
            }
         |