@etherisc/gif-next 0.0.2-e769e2e-077 → 0.0.2-e802d97-713
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 +2 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +19 -13
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +79 -73
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +114 -56
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +11 -5
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +7 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +25 -6
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +12 -22
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +47 -20
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +126 -30
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +195 -64
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +77 -63
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +104 -34
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +246 -104
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -2
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.json +10 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +662 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +997 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +718 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +55 -41
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +102 -40
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +7 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +11 -5
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +22 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +18 -12
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +56 -35
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +95 -37
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +39 -25
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +96 -34
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +81 -67
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +115 -53
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +7 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +7 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +7 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +7 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +11 -5
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +7 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +59 -45
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +104 -42
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +69 -55
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +109 -47
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +18 -12
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +25 -19
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +87 -29
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +150 -53
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +187 -67
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +328 -103
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +197 -72
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +87 -39
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +752 -148
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +2 -2
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +185 -135
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +18 -12
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +92 -63
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +102 -46
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +7 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +11 -5
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +14 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +11 -5
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +0 -10
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +7 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +18 -12
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +10 -20
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +6 -6
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +13 -7
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +64 -16
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +15 -9
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +7 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +424 -593
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +497 -49
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +444 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +598 -627
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +149 -48
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +593 -74
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +119 -29
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2189 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +40 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +2 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +28 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +15 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +2 -4
- package/contracts/distribution/DistributionService.sol +3 -2
- package/contracts/distribution/DistributionServiceManager.sol +9 -18
- package/contracts/distribution/IDistributionComponent.sol +1 -1
- package/contracts/distribution/IDistributionService.sol +1 -1
- package/contracts/instance/IInstance.sol +11 -6
- package/contracts/instance/IInstanceService.sol +3 -5
- package/contracts/instance/Instance.sol +29 -21
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +192 -151
- package/contracts/instance/InstanceReader.sol +30 -6
- package/contracts/instance/InstanceService.sol +69 -55
- package/contracts/instance/InstanceServiceManager.sol +10 -20
- package/contracts/instance/InstanceStore.sol +64 -42
- package/contracts/instance/base/BalanceStore.sol +1 -1
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/module/IAccess.sol +2 -10
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +277 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +6 -23
- package/contracts/pool/BundleServiceManager.sol +9 -18
- package/contracts/pool/IBundleService.sol +1 -1
- package/contracts/pool/IPoolService.sol +4 -1
- package/contracts/pool/PoolService.sol +45 -13
- package/contracts/pool/PoolServiceManager.sol +9 -18
- package/contracts/product/ApplicationService.sol +6 -5
- package/contracts/product/ApplicationServiceManager.sol +9 -6
- package/contracts/product/ClaimService.sol +13 -7
- package/contracts/product/ClaimServiceManager.sol +9 -6
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +1 -1
- package/contracts/product/IPricingService.sol +1 -1
- package/contracts/product/IProductService.sol +1 -1
- package/contracts/product/PolicyService.sol +10 -6
- package/contracts/product/PolicyServiceManager.sol +9 -21
- package/contracts/product/PricingService.sol +10 -9
- package/contracts/product/PricingServiceManager.sol +9 -18
- package/contracts/product/Product.sol +1 -1
- package/contracts/product/ProductService.sol +7 -5
- package/contracts/product/ProductServiceManager.sol +9 -21
- package/contracts/registry/ChainNft.sol +1 -0
- package/contracts/registry/IRegistry.sol +37 -24
- package/contracts/registry/IRegistryService.sol +26 -36
- package/contracts/registry/Registry.sol +164 -117
- package/contracts/registry/RegistryAdmin.sol +237 -0
- package/contracts/registry/RegistryService.sol +22 -83
- package/contracts/registry/RegistryServiceManager.sol +21 -23
- package/contracts/registry/ReleaseManager.sol +448 -223
- package/contracts/registry/TokenRegistry.sol +187 -59
- package/contracts/shared/AccessManagerCustom.sol +736 -0
- package/contracts/shared/AccessManagerExtended.sol +470 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/shared/Component.sol +8 -13
- package/contracts/shared/ComponentService.sol +35 -13
- package/contracts/shared/ComponentVerifyingService.sol +13 -7
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +3 -7
- package/contracts/shared/IComponentService.sol +11 -0
- package/contracts/shared/IKeyValueStore.sol +1 -1
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +1 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +1 -2
- package/contracts/shared/KeyValueStore.sol +24 -66
- package/contracts/shared/Lifecycle.sol +11 -2
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +2 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +31 -1
- package/contracts/shared/Service.sol +1 -1
- package/contracts/staking/IStaking.sol +127 -36
- package/contracts/staking/IStakingService.sol +83 -39
- package/contracts/staking/StakeManagerLib.sol +179 -0
- package/contracts/staking/Staking.sol +432 -93
- package/contracts/staking/StakingManager.sol +22 -14
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +245 -39
- package/contracts/staking/StakingServiceManager.sol +8 -4
- package/contracts/staking/StakingStore.sol +572 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +15 -1
- package/contracts/type/Blocknumber.sol +14 -2
- package/contracts/type/Fee.sol +1 -1
- package/contracts/type/NftId.sol +9 -4
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +12 -9
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +16 -8
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +3 -3
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -308
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/registry/RegistryAccessManager.sol +0 -213
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
@@ -1,22 +1,34 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {AccessManaged} from "@openzeppelin/contracts/access/manager/AccessManaged.sol";
|
4
5
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
6
|
import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165Checker.sol";
|
6
7
|
|
8
|
+
import {REGISTRY} from "../type/ObjectType.sol";
|
9
|
+
import {VersionPart} from "../type/Version.sol";
|
10
|
+
|
7
11
|
import {IRegisterable} from "../shared/IRegisterable.sol";
|
12
|
+
|
8
13
|
import {IRegistry} from "./IRegistry.sol";
|
9
|
-
import {
|
10
|
-
import {
|
11
|
-
import {
|
14
|
+
import {IRegistryLinked} from "../shared/IRegistryLinked.sol";
|
15
|
+
import {ReleaseManager} from "./ReleaseManager.sol";
|
16
|
+
import {RegistryAdmin} from "./RegistryAdmin.sol";
|
17
|
+
|
12
18
|
|
13
19
|
/// @title contract to register token per GIF major release.
|
14
20
|
contract TokenRegistry is
|
15
|
-
|
21
|
+
AccessManaged,
|
22
|
+
IRegistryLinked
|
16
23
|
{
|
17
24
|
event LogTokenRegistryTokenRegistered(uint256 chainId, address token, uint256 decimals, string symbol);
|
25
|
+
event LogTokenRegistryTokenGlobalStateSet(uint256 chainId, address token, bool active);
|
18
26
|
event LogTokenRegistryTokenStateSet(uint256 chainId, address token, VersionPart majorVersion, bool active);
|
19
27
|
|
28
|
+
error ErrorTokenRegistryChainIdZero();
|
29
|
+
error ErrorTokenRegistryTokenAddressZero();
|
30
|
+
|
31
|
+
error ErrorTokenRegistryNotRemoteToken(uint256 chainId, address token);
|
20
32
|
error ErrorTokenRegistryTokenAlreadyRegistered(uint256 chainId, address token);
|
21
33
|
error ErrorTokenRegistryTokenNotContract(uint256 chainId, address token);
|
22
34
|
error ErrorTokenRegistryTokenNotErc20(uint256 chainId, address token);
|
@@ -29,79 +41,115 @@ contract TokenRegistry is
|
|
29
41
|
address token;
|
30
42
|
uint8 decimals;
|
31
43
|
string symbol;
|
44
|
+
bool active;
|
32
45
|
}
|
33
46
|
|
34
|
-
TokenInfo
|
35
|
-
mapping(uint256 chainId => mapping(address token => bool registered)) internal _registered;
|
47
|
+
mapping(uint256 chainId => mapping(address token => TokenInfo info)) internal _tokenInfo;
|
36
48
|
mapping(uint256 chainId => mapping(address token => mapping(VersionPart majorVersion => bool isActive))) internal _active;
|
49
|
+
TokenInfo [] internal _token;
|
37
50
|
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
51
|
+
IRegistry internal _registry;
|
52
|
+
ReleaseManager internal _releaseManager;
|
53
|
+
IERC20Metadata internal _dipToken;
|
54
|
+
|
55
|
+
/// @dev enforces msg.sender is owner of nft (or initial owner of nft ownable)
|
56
|
+
modifier onlyRegisteredToken(uint256 chainId, address token) {
|
57
|
+
if (!isRegistered(chainId, token)) {
|
58
|
+
revert ErrorTokenRegistryTokenNotRegistered(chainId, token);
|
59
|
+
}
|
60
|
+
_;
|
43
61
|
}
|
44
62
|
|
45
|
-
|
46
|
-
|
47
|
-
initializer()
|
63
|
+
constructor(IRegistry registry, IERC20Metadata dipToken)
|
64
|
+
AccessManaged(msg.sender)
|
48
65
|
{
|
49
|
-
|
66
|
+
// set authority
|
67
|
+
address authority = RegistryAdmin(registry.getRegistryAdminAddress()).authority();
|
68
|
+
setAuthority(authority);
|
69
|
+
|
70
|
+
_registry = registry;
|
71
|
+
_dipToken = dipToken;
|
72
|
+
|
73
|
+
// register dip token
|
74
|
+
uint256 chainId = block.chainid;
|
75
|
+
_registerToken(
|
76
|
+
chainId,
|
77
|
+
address(_dipToken),
|
78
|
+
_dipToken.decimals(),
|
79
|
+
_dipToken.symbol());
|
50
80
|
}
|
51
81
|
|
52
82
|
|
53
|
-
/// @dev
|
54
|
-
function
|
83
|
+
/// @dev register an onchain token.
|
84
|
+
/// this function verifies that the provided token address is a contract that implements
|
85
|
+
/// the non optional erc20 view functions.
|
86
|
+
function registerToken(address tokenAddress)
|
55
87
|
external
|
88
|
+
restricted()
|
56
89
|
{
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
_linkToNftOwnable(registryServiceAddress);
|
90
|
+
IERC20Metadata token = _verifyOnchainToken(tokenAddress);
|
91
|
+
_registerToken(block.chainid, tokenAddress, token.decimals(), token.symbol());
|
61
92
|
}
|
62
93
|
|
63
94
|
|
64
|
-
|
95
|
+
/// @dev register the remote token with the provided attributes.
|
96
|
+
/// this function may not be used for tokens when chainId == block.chainid.
|
97
|
+
function registerRemoteToken(
|
98
|
+
uint256 chainId,
|
99
|
+
address token,
|
100
|
+
uint8 decimals,
|
101
|
+
string memory symbol
|
102
|
+
)
|
65
103
|
external
|
66
|
-
|
104
|
+
restricted()
|
67
105
|
{
|
68
|
-
|
69
|
-
|
70
|
-
if (_registered[chainId][token]) {
|
71
|
-
revert ErrorTokenRegistryTokenAlreadyRegistered(chainId, token);
|
106
|
+
if (chainId == block.chainid) {
|
107
|
+
revert ErrorTokenRegistryNotRemoteToken(chainId, token);
|
72
108
|
}
|
73
109
|
|
74
|
-
|
75
|
-
|
76
|
-
revert ErrorTokenRegistryTokenNotContract(chainId, token);
|
77
|
-
}
|
110
|
+
_registerToken(chainId, token, decimals, symbol);
|
111
|
+
}
|
78
112
|
|
79
|
-
// MUST have decimals > 0 (indicator that this is in fact an erc20 token)
|
80
|
-
IERC20Metadata erc20 = IERC20Metadata(token);
|
81
|
-
if(!_implementsErc20Functions(erc20)) {
|
82
|
-
revert ErrorTokenRegistryTokenNotErc20(chainId, token);
|
83
|
-
}
|
84
113
|
|
85
|
-
|
114
|
+
/// @dev set active flag on token itself.
|
115
|
+
/// when setting a token to active=false isActive will return false
|
116
|
+
/// regardless of release specific active value.
|
117
|
+
function setActive(
|
118
|
+
uint256 chainId,
|
119
|
+
address token,
|
120
|
+
bool active
|
121
|
+
)
|
122
|
+
external
|
123
|
+
restricted()
|
124
|
+
onlyRegisteredToken(chainId, token)
|
125
|
+
{
|
126
|
+
_tokenInfo[chainId][token].active = active;
|
127
|
+
emit LogTokenRegistryTokenGlobalStateSet(chainId, token, active);
|
86
128
|
}
|
87
129
|
|
88
130
|
|
89
|
-
/// @dev
|
90
|
-
|
91
|
-
|
92
|
-
|
131
|
+
/// @dev sets active state for specified token and major version.
|
132
|
+
/// internally calls setActiveWithVersionCheck() with enforcing version check.
|
133
|
+
/// token state is informative, registry have no clue about used tokens
|
134
|
+
/// component owner is responsible for token selection and operations
|
135
|
+
/// service MUST deny registration of component with inactive token.
|
136
|
+
function setActiveForVersion(
|
93
137
|
uint256 chainId,
|
94
138
|
address token,
|
95
139
|
VersionPart majorVersion,
|
96
140
|
bool active
|
97
141
|
)
|
98
142
|
external
|
99
|
-
|
143
|
+
restricted()
|
144
|
+
onlyRegisteredToken(chainId, token)
|
100
145
|
{
|
101
|
-
|
146
|
+
_setActiveWithVersionCheck(chainId, token, majorVersion, active, true);
|
102
147
|
}
|
103
148
|
|
104
149
|
|
150
|
+
/// @dev as setActiveForVersion() with the option to skip the version check.
|
151
|
+
/// enforcing the version check checks if the provided major version with the release manager.
|
152
|
+
/// the function reverts if the provided majorVersion is unknown to the release manager.
|
105
153
|
function setActiveWithVersionCheck(
|
106
154
|
uint256 chainId,
|
107
155
|
address token,
|
@@ -109,18 +157,27 @@ contract TokenRegistry is
|
|
109
157
|
bool active,
|
110
158
|
bool enforceVersionCheck
|
111
159
|
)
|
112
|
-
|
113
|
-
|
160
|
+
external
|
161
|
+
restricted()
|
162
|
+
onlyRegisteredToken(chainId, token)
|
114
163
|
{
|
115
|
-
|
116
|
-
|
117
|
-
revert ErrorTokenRegistryTokenNotRegistered(chainId, token);
|
118
|
-
}
|
164
|
+
_setActiveWithVersionCheck(chainId, token, majorVersion, active, enforceVersionCheck);
|
165
|
+
}
|
119
166
|
|
167
|
+
|
168
|
+
function _setActiveWithVersionCheck(
|
169
|
+
uint256 chainId,
|
170
|
+
address token,
|
171
|
+
VersionPart majorVersion,
|
172
|
+
bool active,
|
173
|
+
bool enforceVersionCheck
|
174
|
+
)
|
175
|
+
internal
|
176
|
+
{
|
120
177
|
// verify valid major version
|
121
178
|
if(enforceVersionCheck) {
|
122
179
|
uint256 version = majorVersion.toInt();
|
123
|
-
if (!getRegistry().
|
180
|
+
if (!getRegistry().isActiveRelease(majorVersion)) {
|
124
181
|
revert ErrorTokenRegistryMajorVersionInvalid(majorVersion);
|
125
182
|
}
|
126
183
|
}
|
@@ -130,22 +187,77 @@ contract TokenRegistry is
|
|
130
187
|
emit LogTokenRegistryTokenStateSet(chainId, token, majorVersion, active);
|
131
188
|
}
|
132
189
|
|
190
|
+
/// @dev returns the dip token for this chain
|
191
|
+
function getDipToken() external view returns (IERC20Metadata dipToken) {
|
192
|
+
return _dipToken;
|
193
|
+
}
|
194
|
+
|
195
|
+
/// @dev returns the number of registered tokens
|
133
196
|
function tokens() external view returns (uint256) {
|
134
197
|
return _token.length;
|
135
198
|
}
|
136
199
|
|
137
|
-
|
200
|
+
/// @dev returns the token info for the specified index position [0 .. tokens() - 1].
|
201
|
+
function getTokenInfo(uint256 idx) external view returns (TokenInfo memory tokenInfo) {
|
138
202
|
return _token[idx];
|
139
203
|
}
|
140
204
|
|
141
|
-
|
142
|
-
|
205
|
+
/// @dev returns the token info for the specified token coordinates.
|
206
|
+
function getTokenInfo(uint256 chainId, address token) external view returns (TokenInfo memory tokenInfo) {
|
207
|
+
return _tokenInfo[chainId][token];
|
208
|
+
}
|
209
|
+
|
210
|
+
/// @dev returns true iff the specified token has been registered for this TokenRegistry contract.
|
211
|
+
function isRegistered(uint256 chainId, address token) public view returns (bool) {
|
212
|
+
return _tokenInfo[chainId][token].chainId > 0;
|
143
213
|
}
|
144
214
|
|
215
|
+
/// @dev returns true iff both the token is active for the specfied version and the global token state is active
|
145
216
|
function isActive(uint256 chainId, address token, VersionPart majorVersion) external view returns (bool) {
|
217
|
+
if(!_tokenInfo[chainId][token].active) {
|
218
|
+
return false;
|
219
|
+
}
|
220
|
+
|
146
221
|
return _active[chainId][token][majorVersion];
|
147
222
|
}
|
148
223
|
|
224
|
+
function getDipTokenAddress() external view returns (address) {
|
225
|
+
return address(_dipToken);
|
226
|
+
}
|
227
|
+
|
228
|
+
//--- IRegistryLinked --------------------------------------------------//
|
229
|
+
|
230
|
+
/// @dev returns the dip token for this chain
|
231
|
+
function getRegistry() public view returns (IRegistry) {
|
232
|
+
return _registry;
|
233
|
+
}
|
234
|
+
|
235
|
+
//--- internal functions ------------------------------------------------//
|
236
|
+
|
237
|
+
|
238
|
+
/// @dev checks if provided token address refers to a smart contract that implements
|
239
|
+
/// erc20 functionality (via its non-optional functions)
|
240
|
+
function _verifyOnchainToken(address tokenAddress)
|
241
|
+
internal
|
242
|
+
virtual
|
243
|
+
view
|
244
|
+
returns (IERC20Metadata token)
|
245
|
+
{
|
246
|
+
token = IERC20Metadata(tokenAddress);
|
247
|
+
uint256 chainId = block.chainid;
|
248
|
+
|
249
|
+
// MUST be contract
|
250
|
+
if(tokenAddress.code.length == 0) {
|
251
|
+
revert ErrorTokenRegistryTokenNotContract(chainId, tokenAddress);
|
252
|
+
}
|
253
|
+
|
254
|
+
// MUST implement required erc20 view functions
|
255
|
+
if(!_implementsErc20Functions(token)) {
|
256
|
+
revert ErrorTokenRegistryTokenNotErc20(chainId, tokenAddress);
|
257
|
+
}
|
258
|
+
}
|
259
|
+
|
260
|
+
|
149
261
|
/// @dev checks availability of non-optional view functions
|
150
262
|
/// https://eips.ethereum.org/EIPS/eip-20#methods
|
151
263
|
function _implementsErc20Functions(IERC20Metadata token) internal view returns (bool implementsErc20Functions) {
|
@@ -170,17 +282,33 @@ contract TokenRegistry is
|
|
170
282
|
return true;
|
171
283
|
}
|
172
284
|
|
173
|
-
/// @dev some sanity checks to prevent unintended registration
|
285
|
+
/// @dev some sanity checks to prevent unintended registration:
|
286
|
+
/// - token not yet registered
|
287
|
+
/// - chainId not zero
|
288
|
+
/// - token address not zero
|
174
289
|
function _registerToken(uint256 chainId, address token, uint8 decimals, string memory symbol) internal {
|
175
290
|
|
176
|
-
|
177
|
-
|
178
|
-
|
291
|
+
if (isRegistered(chainId, token)) {
|
292
|
+
revert ErrorTokenRegistryTokenAlreadyRegistered(chainId, token);
|
293
|
+
}
|
294
|
+
|
295
|
+
if(chainId == 0) {
|
296
|
+
revert ErrorTokenRegistryChainIdZero();
|
297
|
+
}
|
298
|
+
|
299
|
+
if(token == address(0)) {
|
300
|
+
revert ErrorTokenRegistryTokenAddressZero();
|
301
|
+
}
|
302
|
+
|
303
|
+
TokenInfo memory tokenInfo = TokenInfo({
|
179
304
|
chainId: chainId,
|
180
305
|
token: token,
|
181
306
|
decimals: decimals,
|
182
|
-
symbol: symbol
|
183
|
-
|
307
|
+
symbol: symbol,
|
308
|
+
active: true});
|
309
|
+
|
310
|
+
_tokenInfo[chainId][token] = tokenInfo;
|
311
|
+
_token.push(tokenInfo);
|
184
312
|
|
185
313
|
emit LogTokenRegistryTokenRegistered(chainId, token, decimals, symbol);
|
186
314
|
}
|