react-native-zcash 0.3.5 → 0.4.0
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/CHANGELOG.md +6 -0
- package/README.md +10 -7
- package/android/build.gradle +6 -4
- package/android/src/main/assets/saplingtree/mainnet/1310000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1320000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1330000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1340000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1350000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1360000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1370000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1380000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1390000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1400000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1410000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1420000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1430000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1440000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1450000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1460000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1470000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1480000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1490000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1500000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1510000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1520000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1530000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1540000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1550000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1560000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1570000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1580000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1590000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1600000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1610000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1620000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1630000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1640000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1650000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1660000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1670000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1680000.json +1 -1
- package/android/src/main/assets/saplingtree/mainnet/1690000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1700000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1710000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1720000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1730000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1740000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1750000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1760000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1770000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1780000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1790000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1800000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1810000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1820000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1830000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1840000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1850000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1860000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1870000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1880000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1890000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1900000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1910000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1920000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1930000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1940000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1950000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1960000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1970000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1980000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/1990000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2000000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2010000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2020000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2030000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2040000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2050000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2060000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2070000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2080000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2090000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2100000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2110000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2120000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2130000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2140000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2150000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2160000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2170000.json +2 -1
- package/android/src/main/assets/saplingtree/mainnet/2180000.json +8 -0
- package/android/src/main/assets/saplingtree/mainnet/2190000.json +8 -0
- package/android/src/main/assets/saplingtree/mainnet/2200000.json +8 -0
- package/android/src/main/assets/saplingtree/mainnet/2210000.json +8 -0
- package/android/src/main/java/app/edge/rnzcash/RNZcashModule.kt +179 -175
- package/android/src/main/java/app/edge/rnzcash/RNZcashPackage.kt +2 -3
- package/ios/RNZcash.m +5 -21
- package/ios/RNZcash.swift +531 -512
- package/ios/ZCashLightClientKit/Block/CompactBlockProcessor.swift +1365 -0
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/ConnectorProvider.swift +12 -0
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/DatabaseStorageError.swift +20 -0
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/SimpleConnectionProvider.swift +39 -0
- package/ios/ZCashLightClientKit/Block/Download/BlockDownloader.swift +295 -0
- package/ios/ZCashLightClientKit/Block/Download/BlockDownloaderService.swift +117 -0
- package/ios/ZCashLightClientKit/Block/Enhance/BlockEnhancer.swift +123 -0
- package/ios/ZCashLightClientKit/Block/FetchUnspentTxOutputs/UTXOFetcher.swift +114 -0
- package/ios/ZCashLightClientKit/Block/FilesystemStorage/FSCompactBlockRepository.swift +419 -0
- package/ios/ZCashLightClientKit/Block/SaplingParameters/SaplingParametersHandler.swift +52 -0
- package/ios/ZCashLightClientKit/Block/Scan/BlockScanner.swift +114 -0
- package/ios/ZCashLightClientKit/Block/Utils/AfterSyncHooksManager.swift +88 -0
- package/ios/ZCashLightClientKit/Block/Utils/InternalSyncProgress.swift +200 -0
- package/ios/ZCashLightClientKit/Block/Validate/BlockValidator.swift +51 -0
- package/ios/ZCashLightClientKit/ClosureSynchronizer.swift +84 -0
- package/ios/ZCashLightClientKit/CombineSynchronizer.swift +76 -0
- package/ios/ZCashLightClientKit/Constants/Checkpoint+Constants.swift +98 -0
- package/ios/ZCashLightClientKit/Constants/Checkpoint+mainnet.swift +19 -0
- package/ios/ZCashLightClientKit/Constants/Checkpoint+testnet.swift +20 -0
- package/ios/ZCashLightClientKit/Constants/ZcashSDK.swift +139 -169
- package/ios/ZCashLightClientKit/DAO/BlockDao.swift +65 -20
- package/ios/ZCashLightClientKit/DAO/PagedTransactionDao.swift +20 -28
- package/ios/ZCashLightClientKit/DAO/TransactionDao.swift +175 -323
- package/ios/ZCashLightClientKit/DAO/UnspentTransactionOutputDao.swift +80 -58
- package/ios/ZCashLightClientKit/Entity/AccountEntity.swift +86 -88
- package/ios/ZCashLightClientKit/Entity/BlockProgress.swift +24 -0
- package/ios/ZCashLightClientKit/Entity/EncodedTransactionEntity.swift +3 -3
- package/ios/ZCashLightClientKit/Entity/SentNoteEntity.swift +15 -12
- package/ios/ZCashLightClientKit/Entity/TransactionEntity.swift +205 -131
- package/ios/ZCashLightClientKit/Entity/UnspentTransactionOutputEntity.swift +7 -6
- package/ios/ZCashLightClientKit/Entity/ZcashCompactBlock.swift +96 -0
- package/ios/ZCashLightClientKit/Error/Sourcery/ZcashError.stencil +40 -0
- package/ios/ZCashLightClientKit/Error/Sourcery/ZcashErrorCode.stencil +15 -0
- package/ios/ZCashLightClientKit/Error/Sourcery/generateErrorCode.sh +34 -0
- package/ios/ZCashLightClientKit/Error/ZcashError.swift +820 -0
- package/ios/ZCashLightClientKit/Error/ZcashErrorCode.swift +306 -0
- package/ios/ZCashLightClientKit/Error/ZcashErrorCodeDefinition.swift +596 -0
- package/ios/ZCashLightClientKit/Extensions/Error+ZcashError.swift +18 -0
- package/ios/ZCashLightClientKit/Extensions/HexEncode.swift +1 -1
- package/ios/ZCashLightClientKit/Extensions/NumberFormatter+Zcash.swift +19 -0
- package/ios/ZCashLightClientKit/Extensions/URL+UpdateWithAlias.swift +36 -0
- package/ios/ZCashLightClientKit/Extensions/Undescribable.swift +22 -0
- package/ios/ZCashLightClientKit/Extensions/Zatoshi+SQLite.swift +20 -0
- package/ios/ZCashLightClientKit/Initializer.swift +336 -260
- package/ios/ZCashLightClientKit/Metrics/SDKMetrics.swift +270 -0
- package/ios/ZCashLightClientKit/Model/Checkpoint.swift +84 -0
- package/ios/ZCashLightClientKit/Model/Memo.swift +236 -0
- package/ios/ZCashLightClientKit/Model/WalletTypes.swift +261 -88
- package/ios/ZCashLightClientKit/Model/Zatoshi.swift +115 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/LightWalletGRPCService.swift +342 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/Extensions/Protocolbuffer+Extensions.swift +50 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/compact_formats.pb.swift +399 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/proto/compact_formats.proto +66 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/proto/service.proto +185 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/service.grpc.swift +1123 -0
- package/ios/ZCashLightClientKit/Modules/Service/GRPC/ProtoBuf/service.pb.swift +1208 -0
- package/ios/ZCashLightClientKit/Modules/Service/LightWalletService.swift +195 -0
- package/ios/ZCashLightClientKit/Providers/LatestBlocksDataProvider.swift +69 -0
- package/ios/ZCashLightClientKit/Providers/ResourceProvider.swift +24 -6
- package/ios/ZCashLightClientKit/Repository/CompactBlockRepository.swift +14 -46
- package/ios/ZCashLightClientKit/Repository/NotesRepository.swift +1 -0
- package/ios/ZCashLightClientKit/Repository/PaginatedTransactionRepository.swift +6 -6
- package/ios/ZCashLightClientKit/Repository/TransactionRepository.swift +18 -19
- package/ios/ZCashLightClientKit/Repository/UnspentTransactionOutputRepository.swift +5 -7
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1000000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1010000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1020000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1030000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1040000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1050000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1060000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1070000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1080000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1090000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1100000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1110000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1120000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1130000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1140000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1150000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1160000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1170000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1180000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1190000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1200000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1210000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1220000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1230000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1240000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1250000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1260000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1270000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1280000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1290000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1300000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1310000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1320000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1330000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1340000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1350000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1360000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1370000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1380000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1390000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1400000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1410000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1420000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1430000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1440000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1450000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1460000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1470000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1480000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1490000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1500000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1510000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1520000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1530000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1540000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1550000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1560000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1570000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1580000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1590000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1600000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1610000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1620000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1630000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1631000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1640000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1650000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1660000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1670000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1680000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1686871.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1687104.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1690000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1700000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1710000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1720000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1722500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1725000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1727500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1730000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1732500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1735000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1737500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1740000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1742500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1745000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1747500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1750000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1752500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1755000.json +9 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1757500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1760000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1762500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1765000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1767500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1770000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1772500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1775000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1777500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1780000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1782500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1785000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1787500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1790000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1792500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1795000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1797500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1800000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1802500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1805000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1807500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1810000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1812500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1815000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1817500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1820000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1822500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1825000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1827500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1830000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1832500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1835000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1837500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1840000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1842500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1845000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1847500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1850000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1852500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1855000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1857500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1860000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1862500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1865000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1867500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1870000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1872500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1875000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1877500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1880000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1882500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1885000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1887500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1890000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1892500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1895000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1897500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1900000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1902500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1905000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1907500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1910000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1912500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1915000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1917500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1920000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1922500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1925000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1927500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1930000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1932500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1935000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1937500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1940000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1942500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1945000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1947500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1950000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1952500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1955000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1957500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1960000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1962500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1965000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1967500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1970000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1972500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1975000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1977500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1980000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1982500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1985000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1987500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1990000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1992500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1995000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/1997500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2000000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2002500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2005000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2007500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2010000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2012500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2015000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2017500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2020000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2022500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2025000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2027500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2030000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2032500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2035000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2037500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2040000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2042500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2045000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2047500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2050000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2052500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2055000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2057500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2060000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2062500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2065000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2067500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2070000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2072500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2075000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2077500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2080000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2082500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2085000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2087500.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2090000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2100000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2110000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2120000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2130000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2140000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2150000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2160000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2170000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2180000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2190000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2200000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/2210000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/419200.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/500000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/510000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/520000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/530000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/540000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/550000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/560000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/570000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/580000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/590000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/600000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/610000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/620000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/630000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/640000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/650000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/660000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/663150.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/670000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/680000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/690000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/700000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/710000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/720000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/730000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/740000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/750000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/760000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/770000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/780000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/790000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/800000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/810000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/820000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/830000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/840000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/850000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/860000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/870000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/880000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/890000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/900000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/910000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/920000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/930000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/940000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/950000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/960000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/970000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/980000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/mainnet/990000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1000000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1010000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1020000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1030000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1040000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1050000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1060000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1070000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1080000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1090000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1100000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1110000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1120000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1130000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1140000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1150000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1160000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1170000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1180000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1190000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1200000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1210000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1220000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1230000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1240000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1250000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1260000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1270000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1280000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1290000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1300000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1310000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1320000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1330000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1340000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1350000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1360000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1370000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1380000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1390000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1400000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1410000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1420000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1430000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1440000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1450000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1460000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1470000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1480000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1490000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1500000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1510000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1520000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1530000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1540000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1550000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1560000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1570000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1580000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1590000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1600000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1610000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1620000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1630000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1640000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1650000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1660000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1670000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1680000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1690000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1700000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1710000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1720000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1730000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1740000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1750000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1760000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1770000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1780000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1790000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1800000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1810000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1820000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1830000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1840000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1842420.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1850000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1860000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1870000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1880000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1890000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1900000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1910000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1920000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1930000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1940000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1950000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1960000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1970000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1980000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/1990000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2000000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2010000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2020000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2030000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2040000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2050000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2060000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2070000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2080000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2090000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2100000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2110000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2120000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2130000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2140000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2150000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2160000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2170000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2180000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2190000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2200000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2210000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2220000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2230000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2240000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2250000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2260000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2270000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2280000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2290000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2300000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2310000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2320000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2330000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/2340000.json +8 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/280000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/290000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/300000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/310000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/320000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/330000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/340000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/350000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/360000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/370000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/380000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/390000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/400000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/410000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/420000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/430000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/440000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/450000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/460000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/470000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/480000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/490000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/500000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/510000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/520000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/530000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/540000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/550000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/560000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/570000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/580000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/590000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/600000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/610000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/620000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/630000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/640000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/650000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/660000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/670000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/680000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/690000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/700000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/710000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/720000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/730000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/740000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/750000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/760000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/770000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/780000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/790000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/800000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/810000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/820000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/830000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/840000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/850000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/860000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/870000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/880000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/890000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/900000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/910000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/920000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/930000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/940000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/950000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/960000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/970000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/980000.json +7 -0
- package/ios/ZCashLightClientKit/Resources/checkpoints/testnet/990000.json +7 -0
- package/ios/ZCashLightClientKit/Rust/ZcashKeyDerivationBackend.swift +218 -0
- package/ios/ZCashLightClientKit/Rust/ZcashKeyDerivationBackendWelding.swift +88 -0
- package/ios/ZCashLightClientKit/Rust/ZcashRustBackend.swift +531 -604
- package/ios/ZCashLightClientKit/Rust/ZcashRustBackendWelding.swift +223 -356
- package/ios/ZCashLightClientKit/Rust/zcashlc.h +802 -136
- package/ios/ZCashLightClientKit/Synchronizer/ClosureSDKSynchronizer.swift +180 -0
- package/ios/ZCashLightClientKit/Synchronizer/CombineSDKSynchronizer.swift +175 -0
- package/ios/ZCashLightClientKit/Synchronizer/Dependencies.swift +207 -0
- package/ios/ZCashLightClientKit/Synchronizer/SDKSynchronizer.swift +527 -793
- package/ios/ZCashLightClientKit/Synchronizer.swift +416 -342
- package/ios/ZCashLightClientKit/Tool/DerivationTool.swift +163 -300
- package/ios/ZCashLightClientKit/Transaction/TransactionEncoder.swift +39 -89
- package/ios/ZCashLightClientKit/Transaction/WalletTransactionEncoder.swift +93 -144
- package/ios/ZCashLightClientKit/Utils/AsyncToClosureGateway.swift +46 -0
- package/ios/ZCashLightClientKit/Utils/AsyncToCombineGateway.swift +59 -0
- package/ios/ZCashLightClientKit/Utils/Clamped.swift +32 -0
- package/ios/ZCashLightClientKit/Utils/DIContainer.swift +86 -0
- package/ios/ZCashLightClientKit/Utils/GenericActor.swift +18 -0
- package/ios/ZCashLightClientKit/Utils/LoggingProxy.swift +22 -21
- package/ios/ZCashLightClientKit/Utils/OSLogger.swift +109 -0
- package/ios/ZCashLightClientKit/Utils/SaplingParameterDownloader.swift +124 -89
- package/ios/ZCashLightClientKit/Utils/SpecificCombineTypes.swift +16 -0
- package/ios/ZCashLightClientKit/Utils/SyncSessionIDGenerator.swift +32 -0
- package/ios/ZCashLightClientKit/Utils/Task+sleep.swift +14 -0
- package/ios/ZCashLightClientKit/Utils/UsedAliasesChecker.swift +41 -0
- package/ios/libzcashlc.xcframework/Info.plist +5 -5
- package/ios/libzcashlc.xcframework/ios-arm64/libzcashlc.a +0 -0
- package/ios/libzcashlc.xcframework/ios-arm64_x86_64-simulator/libzcashlc.a +0 -0
- package/lib/rnzcash.rn.js +37 -80
- package/lib/rnzcash.rn.js.map +1 -1
- package/lib/src/react-native.d.ts +5 -10
- package/lib/src/types.d.ts +3 -4
- package/package.json +4 -1
- package/react-native-zcash.podspec +5 -4
- package/src/react-native.ts +15 -41
- package/src/types.ts +3 -4
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/CompactBlockStorage.swift +0 -123
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/DatabaseMigrationManager.swift +0 -222
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/StorageError.swift +0 -22
- package/ios/ZCashLightClientKit/Block/DatabaseStorage/StorageManager.swift +0 -73
- package/ios/ZCashLightClientKit/Block/Downloader/BlockDownloader.swift +0 -240
- package/ios/ZCashLightClientKit/Block/Downloader/CompactBlockDownloaderBuilder.swift +0 -26
- package/ios/ZCashLightClientKit/Block/Processor/CompactBlockDownloadOperation.swift +0 -258
- package/ios/ZCashLightClientKit/Block/Processor/CompactBlockEnhancementOperation.swift +0 -157
- package/ios/ZCashLightClientKit/Block/Processor/CompactBlockProcessor.swift +0 -1454
- package/ios/ZCashLightClientKit/Block/Processor/CompactBlockScanningOperation.swift +0 -238
- package/ios/ZCashLightClientKit/Block/Processor/CompactBlockValidationInformation.swift +0 -66
- package/ios/ZCashLightClientKit/Block/Processor/FetchUnspentTxOutputsOperation.swift +0 -103
- package/ios/ZCashLightClientKit/Block/Processor/FigureNextBatchOperation.swift +0 -58
- package/ios/ZCashLightClientKit/Block/Processor/ZcashOperation.swift +0 -68
- package/ios/ZCashLightClientKit/Constants/WalletBirthday+Constants.swift +0 -58
- package/ios/ZCashLightClientKit/Constants/WalletBirthday+mainnet.swift +0 -20
- package/ios/ZCashLightClientKit/Constants/WalletBirthday+testnet.swift +0 -20
- package/ios/ZCashLightClientKit/DAO/CompactBlockDAO.swift +0 -24
- package/ios/ZCashLightClientKit/DAO/NotesDao.swift +0 -142
- package/ios/ZCashLightClientKit/DAO/PendingTransactionDao.swift +0 -213
- package/ios/ZCashLightClientKit/DAO/TransactionBuilder.swift +0 -169
- package/ios/ZCashLightClientKit/Entity/CompactBlockEntity.swift +0 -13
- package/ios/ZCashLightClientKit/Entity/PendingTransactionEntity.swift +0 -205
- package/ios/ZCashLightClientKit/Entity/ReceivedNoteEntity.swift +0 -22
- package/ios/ZCashLightClientKit/Repository/PendingTransactionRepository.swift +0 -19
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1000000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1010000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1020000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1030000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1040000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1050000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1060000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1070000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1080000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1090000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1100000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1110000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1120000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1130000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1140000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1150000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1160000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1170000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1180000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1190000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1200000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1210000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1220000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1230000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1240000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1250000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1260000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1270000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1280000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1290000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1300000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1310000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1320000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1330000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1340000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1350000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1360000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1370000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1380000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1390000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1400000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1410000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1420000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1430000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1440000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1450000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1460000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1470000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1480000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1490000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1500000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1510000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1520000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1530000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1540000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1550000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1560000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1570000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1580000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1590000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1600000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1610000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1620000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1630000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1640000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1650000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1660000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1670000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1680000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1690000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1700000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1710000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1720000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1730000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1740000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1750000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1760000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1770000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1780000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1790000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1800000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1810000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1820000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1830000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1840000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1850000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1860000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1870000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1880000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1890000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1900000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1910000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1920000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1930000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1940000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1950000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1960000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1970000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1980000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/1990000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2000000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2010000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2020000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2030000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2040000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2050000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2060000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2070000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2080000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2090000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2100000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2110000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2120000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2130000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2140000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2150000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2160000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/2170000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/419200.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/500000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/510000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/520000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/530000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/540000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/550000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/560000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/570000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/580000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/590000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/600000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/610000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/620000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/630000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/640000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/650000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/660000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/663150.json +0 -8
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/670000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/680000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/690000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/700000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/710000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/720000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/730000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/740000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/750000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/760000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/770000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/780000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/790000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/800000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/810000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/820000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/830000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/840000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/850000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/860000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/870000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/880000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/890000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/900000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/910000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/920000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/930000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/940000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/950000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/960000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/970000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/980000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/mainnet/990000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1000000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1010000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1020000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1030000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1040000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1050000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1060000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1070000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1080000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1090000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1100000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1110000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1120000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1130000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1140000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1150000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1160000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1170000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1180000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1190000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1200000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1210000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1220000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1230000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1240000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1250000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1260000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1270000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1280000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1290000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1300000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1310000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1320000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1330000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1340000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1350000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1360000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1370000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1380000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1390000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1400000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1410000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1420000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1430000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1440000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1450000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1460000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1470000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1480000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1490000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1500000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1510000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1520000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1530000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1540000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1550000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1560000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1570000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1580000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1590000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1600000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1610000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1620000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1630000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1640000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1650000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1660000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1670000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1680000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1690000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1700000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1710000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1720000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1730000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1740000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1750000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1760000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1770000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1780000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1790000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1800000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1810000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1820000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1830000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1840000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1850000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/1860000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/280000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/290000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/300000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/310000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/320000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/330000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/340000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/350000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/360000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/370000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/380000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/390000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/400000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/410000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/420000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/430000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/440000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/450000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/460000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/470000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/480000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/490000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/500000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/510000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/520000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/530000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/540000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/550000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/560000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/570000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/580000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/590000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/600000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/610000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/620000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/630000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/640000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/650000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/660000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/670000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/680000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/690000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/700000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/710000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/720000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/730000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/740000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/750000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/760000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/770000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/780000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/790000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/800000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/810000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/820000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/830000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/840000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/850000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/860000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/870000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/880000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/890000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/900000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/910000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/920000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/930000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/940000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/950000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/960000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/970000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/980000.json +0 -7
- package/ios/ZCashLightClientKit/Resources/saplingtree-checkpoints/testnet/990000.json +0 -7
- package/ios/ZCashLightClientKit/Service/LightWalletGRPCService.swift +0 -551
- package/ios/ZCashLightClientKit/Service/LightWalletService.swift +0 -214
- package/ios/ZCashLightClientKit/Service/Model/ZcashCompactBlock.swift +0 -46
- package/ios/ZCashLightClientKit/Service/ProtoBuf/Extensions/Protocolbuffer+Extensions.swift +0 -50
- package/ios/ZCashLightClientKit/Service/ProtoBuf/compact_formats.pb.swift +0 -332
- package/ios/ZCashLightClientKit/Service/ProtoBuf/proto/compact_formats.proto +0 -56
- package/ios/ZCashLightClientKit/Service/ProtoBuf/proto/service.proto +0 -180
- package/ios/ZCashLightClientKit/Service/ProtoBuf/service.grpc.swift +0 -383
- package/ios/ZCashLightClientKit/Service/ProtoBuf/service.pb.swift +0 -1173
- package/ios/ZCashLightClientKit/Transaction/PersistentTransactionManager.swift +0 -339
- package/ios/ZCashLightClientKit/Transaction/TransactionManager.swift +0 -42
- package/ios/ZCashLightClientKit/Utils/Bundle+module.swift +0 -30
|
@@ -7,923 +7,657 @@
|
|
|
7
7
|
//
|
|
8
8
|
|
|
9
9
|
import Foundation
|
|
10
|
+
import Combine
|
|
10
11
|
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
Notification is posted whenever transactions are updated
|
|
14
|
-
|
|
15
|
-
- Important: not yet posted
|
|
16
|
-
*/
|
|
17
|
-
static let transactionsUpdated = Notification.Name("SDKSyncronizerTransactionUpdated")
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
Posted when the synchronizer is started.
|
|
21
|
-
*/
|
|
22
|
-
static let synchronizerStarted = Notification.Name("SDKSyncronizerStarted")
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
Posted when there are progress updates.
|
|
26
|
-
|
|
27
|
-
- Note: Query userInfo object for NotificationKeys.progress for Float progress percentage and NotificationKeys.blockHeight for the current progress height
|
|
28
|
-
*/
|
|
29
|
-
static let synchronizerProgressUpdated = Notification.Name("SDKSyncronizerProgressUpdated")
|
|
30
|
-
|
|
31
|
-
static let synchronizerStatusWillUpdate = Notification.Name("SDKSynchronizerStatusWillUpdate")
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
Posted when the synchronizer is synced to latest height
|
|
35
|
-
*/
|
|
36
|
-
static let synchronizerSynced = Notification.Name("SDKSyncronizerSynced")
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
Posted when the synchronizer is stopped
|
|
40
|
-
*/
|
|
41
|
-
static let synchronizerStopped = Notification.Name("SDKSyncronizerStopped")
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
Posted when the synchronizer loses connection
|
|
45
|
-
*/
|
|
46
|
-
static let synchronizerDisconnected = Notification.Name("SDKSyncronizerDisconnected")
|
|
47
|
-
|
|
48
|
-
/**
|
|
49
|
-
Posted when the synchronizer starts syncing
|
|
50
|
-
*/
|
|
51
|
-
static let synchronizerSyncing = Notification.Name("SDKSyncronizerSyncing")
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
Posted when synchronizer starts downloading blocks
|
|
55
|
-
*/
|
|
56
|
-
static let synchronizerDownloading = Notification.Name("SDKSyncronizerDownloading")
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
Posted when synchronizer starts validating blocks
|
|
60
|
-
*/
|
|
61
|
-
static let synchronizerValidating = Notification.Name("SDKSyncronizerValidating")
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
Posted when synchronizer starts scanning blocks
|
|
65
|
-
*/
|
|
66
|
-
static let synchronizerScanning = Notification.Name("SDKSyncronizerScanning")
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
Posted when the synchronizer starts Enhancing
|
|
70
|
-
*/
|
|
71
|
-
static let synchronizerEnhancing = Notification.Name("SDKSyncronizerEnhancing")
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
Posted when the synchronizer starts fetching UTXOs
|
|
75
|
-
*/
|
|
76
|
-
static let synchronizerFetching = Notification.Name("SDKSyncronizerFetching")
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
Posted when the synchronizer finds a pendingTransaction that hast been newly mined
|
|
80
|
-
- Note: query userInfo on NotificationKeys.minedTransaction for the transaction
|
|
81
|
-
*/
|
|
82
|
-
static let synchronizerMinedTransaction = Notification.Name("synchronizerMinedTransaction")
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
Posted when the synchronizer finds a mined transaction
|
|
86
|
-
- Note: query userInfo on NotificationKeys.foundTransactions for the [ConfirmedTransactionEntity]. This notification could arrive in a background thread.
|
|
87
|
-
*/
|
|
88
|
-
static let synchronizerFoundTransactions = Notification.Name("synchronizerFoundTransactions")
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
Posted when the synchronizer presents an error
|
|
92
|
-
- Note: query userInfo on NotificationKeys.error for an error
|
|
93
|
-
*/
|
|
94
|
-
static let synchronizerFailed = Notification.Name("SDKSynchronizerFailed")
|
|
95
|
-
|
|
96
|
-
static let synchronizerConnectionStateChanged = Notification.Name("SynchronizerConnectionStateChanged")
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
Synchronizer implementation for UIKit and iOS 12+
|
|
101
|
-
*/
|
|
12
|
+
/// Synchronizer implementation for UIKit and iOS 13+
|
|
102
13
|
// swiftlint:disable type_body_length
|
|
103
14
|
public class SDKSynchronizer: Synchronizer {
|
|
104
|
-
public
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
15
|
+
public var alias: ZcashSynchronizerAlias { initializer.alias }
|
|
16
|
+
|
|
17
|
+
private lazy var streamsUpdateQueue = { DispatchQueue(label: "streamsUpdateQueue_\(initializer.alias.description)") }()
|
|
18
|
+
private let stateSubject = CurrentValueSubject<SynchronizerState, Never>(.zero)
|
|
19
|
+
public var stateStream: AnyPublisher<SynchronizerState, Never> { stateSubject.eraseToAnyPublisher() }
|
|
20
|
+
public private(set) var latestState: SynchronizerState = .zero
|
|
21
|
+
|
|
22
|
+
private let eventSubject = PassthroughSubject<SynchronizerEvent, Never>()
|
|
23
|
+
public var eventStream: AnyPublisher<SynchronizerEvent, Never> { eventSubject.eraseToAnyPublisher() }
|
|
24
|
+
|
|
25
|
+
public let metrics: SDKMetrics
|
|
26
|
+
public let logger: Logger
|
|
116
27
|
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
}
|
|
121
|
-
willSet {
|
|
122
|
-
notifyStatusChange(newValue: newValue, oldValue: status)
|
|
123
|
-
}
|
|
28
|
+
// Don't read this variable directly. Use `status` instead. And don't update this variable directly use `updateStatus()` methods instead.
|
|
29
|
+
private var underlyingStatus: GenericActor<InternalSyncStatus>
|
|
30
|
+
var status: InternalSyncStatus {
|
|
31
|
+
get async { await underlyingStatus.value }
|
|
124
32
|
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
public
|
|
130
|
-
public
|
|
131
|
-
|
|
132
|
-
private
|
|
133
|
-
private
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
33
|
+
|
|
34
|
+
let blockProcessor: CompactBlockProcessor
|
|
35
|
+
lazy var blockProcessorEventProcessingQueue = { DispatchQueue(label: "blockProcessorEventProcessingQueue_\(initializer.alias.description)") }()
|
|
36
|
+
|
|
37
|
+
public let initializer: Initializer
|
|
38
|
+
public var connectionState: ConnectionState
|
|
39
|
+
public let network: ZcashNetwork
|
|
40
|
+
private let transactionEncoder: TransactionEncoder
|
|
41
|
+
private let transactionRepository: TransactionRepository
|
|
42
|
+
private let utxoRepository: UnspentTransactionOutputRepository
|
|
43
|
+
|
|
44
|
+
private let syncSessionIDGenerator: SyncSessionIDGenerator
|
|
45
|
+
private let syncSession: SyncSession
|
|
46
|
+
private let syncSessionTicker: SessionTicker
|
|
47
|
+
private var syncStartDate: Date?
|
|
48
|
+
let latestBlocksDataProvider: LatestBlocksDataProvider
|
|
49
|
+
|
|
50
|
+
/// Creates an SDKSynchronizer instance
|
|
51
|
+
/// - Parameter initializer: a wallet Initializer object
|
|
52
|
+
public convenience init(initializer: Initializer) {
|
|
53
|
+
self.init(
|
|
141
54
|
status: .unprepared,
|
|
142
55
|
initializer: initializer,
|
|
143
|
-
|
|
56
|
+
transactionEncoder: WalletTransactionEncoder(initializer: initializer),
|
|
144
57
|
transactionRepository: initializer.transactionRepository,
|
|
145
|
-
utxoRepository:
|
|
146
|
-
blockProcessor: CompactBlockProcessor(
|
|
58
|
+
utxoRepository: UTXORepositoryBuilder.build(initializer: initializer),
|
|
59
|
+
blockProcessor: CompactBlockProcessor(
|
|
60
|
+
initializer: initializer,
|
|
61
|
+
walletBirthdayProvider: { initializer.walletBirthday }
|
|
62
|
+
),
|
|
63
|
+
syncSessionTicker: .live
|
|
147
64
|
)
|
|
148
65
|
}
|
|
149
|
-
|
|
66
|
+
|
|
150
67
|
init(
|
|
151
|
-
status:
|
|
68
|
+
status: InternalSyncStatus,
|
|
152
69
|
initializer: Initializer,
|
|
153
|
-
|
|
70
|
+
transactionEncoder: TransactionEncoder,
|
|
154
71
|
transactionRepository: TransactionRepository,
|
|
155
72
|
utxoRepository: UnspentTransactionOutputRepository,
|
|
156
|
-
blockProcessor: CompactBlockProcessor
|
|
157
|
-
|
|
73
|
+
blockProcessor: CompactBlockProcessor,
|
|
74
|
+
syncSessionTicker: SessionTicker
|
|
75
|
+
) {
|
|
158
76
|
self.connectionState = .idle
|
|
159
|
-
self.
|
|
77
|
+
self.underlyingStatus = GenericActor(status)
|
|
160
78
|
self.initializer = initializer
|
|
161
|
-
self.
|
|
79
|
+
self.transactionEncoder = transactionEncoder
|
|
162
80
|
self.transactionRepository = transactionRepository
|
|
163
81
|
self.utxoRepository = utxoRepository
|
|
164
82
|
self.blockProcessor = blockProcessor
|
|
165
|
-
self.latestScannedHeight = (try? transactionRepository.lastScannedHeight()) ?? initializer.walletBirthday.height
|
|
166
83
|
self.network = initializer.network
|
|
167
|
-
self.
|
|
84
|
+
self.metrics = initializer.container.resolve(SDKMetrics.self)
|
|
85
|
+
self.logger = initializer.logger
|
|
86
|
+
self.syncSessionIDGenerator = initializer.container.resolve(SyncSessionIDGenerator.self)
|
|
87
|
+
self.syncSession = SyncSession(.nullID)
|
|
88
|
+
self.syncSessionTicker = syncSessionTicker
|
|
89
|
+
self.latestBlocksDataProvider = initializer.container.resolve(LatestBlocksDataProvider.self)
|
|
90
|
+
|
|
91
|
+
initializer.lightWalletService.connectionStateChange = { [weak self] oldState, newState in
|
|
92
|
+
self?.connectivityStateChanged(oldState: oldState, newState: newState)
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
Task(priority: .high) { [weak self] in await self?.subscribeToProcessorEvents(blockProcessor) }
|
|
168
96
|
}
|
|
169
|
-
|
|
97
|
+
|
|
170
98
|
deinit {
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
public func initialize() throws {
|
|
176
|
-
try self.initializer.initialize()
|
|
177
|
-
try self.blockProcessor.setStartHeight(initializer.walletBirthday.height)
|
|
99
|
+
UsedAliasesChecker.stopUsing(alias: initializer.alias, id: initializer.id)
|
|
100
|
+
Task { [blockProcessor] in
|
|
101
|
+
await blockProcessor.stop()
|
|
102
|
+
}
|
|
178
103
|
}
|
|
179
|
-
|
|
180
|
-
public func prepare() throws {
|
|
181
|
-
try self.initializer.initialize()
|
|
182
|
-
try self.blockProcessor.setStartHeight(initializer.walletBirthday.height)
|
|
183
|
-
self.status = .disconnected
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
Starts the synchronizer
|
|
188
|
-
- Throws: CompactBlockProcessorError when failures occur
|
|
189
|
-
*/
|
|
190
|
-
public func start(retry: Bool = false) throws {
|
|
191
|
-
switch status {
|
|
192
|
-
case .unprepared:
|
|
193
|
-
throw SynchronizerError.notPrepared
|
|
194
|
-
|
|
195
|
-
case .downloading, .validating, .scanning, .enhancing, .fetching:
|
|
196
|
-
LoggerProxy.warn("warning: synchronizer started when already started")
|
|
197
|
-
return
|
|
198
104
|
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
} catch {
|
|
203
|
-
throw mapError(error)
|
|
204
|
-
}
|
|
205
|
-
}
|
|
105
|
+
func updateStatus(_ newValue: InternalSyncStatus) async {
|
|
106
|
+
let oldValue = await underlyingStatus.update(newValue)
|
|
107
|
+
await notify(oldStatus: oldValue, newStatus: newValue)
|
|
206
108
|
}
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
public func stop() {
|
|
212
|
-
guard status != .stopped, status != .disconnected else {
|
|
213
|
-
LoggerProxy.info("attempted to stop when status was: \(status)")
|
|
214
|
-
return
|
|
109
|
+
|
|
110
|
+
func throwIfUnprepared() throws {
|
|
111
|
+
if !latestState.internalSyncStatus.isPrepared {
|
|
112
|
+
throw ZcashError.synchronizerNotPrepared
|
|
215
113
|
}
|
|
216
|
-
|
|
217
|
-
blockProcessor.stop(cancelTasks: true)
|
|
218
|
-
self.status = .stopped
|
|
219
114
|
}
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
let
|
|
223
|
-
|
|
224
|
-
center.addObserver(
|
|
225
|
-
self,
|
|
226
|
-
selector: #selector(processorUpdated(_:)),
|
|
227
|
-
name: Notification.Name.blockProcessorUpdated,
|
|
228
|
-
object: processor
|
|
229
|
-
)
|
|
230
|
-
|
|
231
|
-
center.addObserver(
|
|
232
|
-
self,
|
|
233
|
-
selector: #selector(processorStartedDownloading(_:)),
|
|
234
|
-
name: Notification.Name.blockProcessorStartedDownloading,
|
|
235
|
-
object: processor
|
|
236
|
-
)
|
|
237
|
-
|
|
238
|
-
center.addObserver(
|
|
239
|
-
self,
|
|
240
|
-
selector: #selector(processorStartedValidating(_:)),
|
|
241
|
-
name: Notification.Name.blockProcessorStartedValidating,
|
|
242
|
-
object: processor
|
|
243
|
-
)
|
|
244
|
-
|
|
245
|
-
center.addObserver(
|
|
246
|
-
self,
|
|
247
|
-
selector: #selector(processorStartedScanning(_:)),
|
|
248
|
-
name: Notification.Name.blockProcessorStartedScanning,
|
|
249
|
-
object: processor
|
|
250
|
-
)
|
|
251
|
-
|
|
252
|
-
center.addObserver(
|
|
253
|
-
self,
|
|
254
|
-
selector: #selector(processorStartedEnhancing(_:)),
|
|
255
|
-
name: Notification.Name.blockProcessorStartedEnhancing,
|
|
256
|
-
object: processor
|
|
257
|
-
)
|
|
258
|
-
|
|
259
|
-
center.addObserver(
|
|
260
|
-
self,
|
|
261
|
-
selector: #selector(processorStartedFetching(_:)),
|
|
262
|
-
name: Notification.Name.blockProcessorStartedFetching,
|
|
263
|
-
object: processor
|
|
264
|
-
)
|
|
265
|
-
|
|
266
|
-
center.addObserver(
|
|
267
|
-
self,
|
|
268
|
-
selector: #selector(processorStopped(_:)),
|
|
269
|
-
name: Notification.Name.blockProcessorStopped,
|
|
270
|
-
object: processor
|
|
271
|
-
)
|
|
272
|
-
|
|
273
|
-
center.addObserver(
|
|
274
|
-
self,
|
|
275
|
-
selector: #selector(processorFailed(_:)),
|
|
276
|
-
name: Notification.Name.blockProcessorFailed,
|
|
277
|
-
object: processor
|
|
278
|
-
)
|
|
279
|
-
|
|
280
|
-
center.addObserver(
|
|
281
|
-
self,
|
|
282
|
-
selector: #selector(processorIdle(_:)),
|
|
283
|
-
name: Notification.Name.blockProcessorIdle,
|
|
284
|
-
object: processor
|
|
285
|
-
)
|
|
286
|
-
|
|
287
|
-
center.addObserver(
|
|
288
|
-
self,
|
|
289
|
-
selector: #selector(processorFinished(_:)),
|
|
290
|
-
name: Notification.Name.blockProcessorFinished,
|
|
291
|
-
object: processor
|
|
292
|
-
)
|
|
293
|
-
|
|
294
|
-
center.addObserver(
|
|
295
|
-
self,
|
|
296
|
-
selector: #selector(processorTransitionUnknown(_:)),
|
|
297
|
-
name: Notification.Name.blockProcessorUnknownTransition,
|
|
298
|
-
object: processor
|
|
299
|
-
)
|
|
300
|
-
|
|
301
|
-
center.addObserver(
|
|
302
|
-
self,
|
|
303
|
-
selector: #selector(reorgDetected(_:)),
|
|
304
|
-
name: Notification.Name.blockProcessorHandledReOrg,
|
|
305
|
-
object: processor
|
|
306
|
-
)
|
|
307
|
-
|
|
308
|
-
center.addObserver(
|
|
309
|
-
self,
|
|
310
|
-
selector: #selector(transactionsFound(_:)),
|
|
311
|
-
name: Notification.Name.blockProcessorFoundTransactions,
|
|
312
|
-
object: processor
|
|
313
|
-
)
|
|
314
|
-
|
|
315
|
-
center.addObserver(
|
|
316
|
-
self,
|
|
317
|
-
selector: #selector(connectivityStateChanged(_:)),
|
|
318
|
-
name: Notification.Name.blockProcessorConnectivityStateChanged,
|
|
319
|
-
object: nil
|
|
320
|
-
)
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
// MARK: Block Processor notifications
|
|
324
|
-
|
|
325
|
-
@objc func connectivityStateChanged(_ notification: Notification) {
|
|
326
|
-
guard
|
|
327
|
-
let userInfo = notification.userInfo,
|
|
328
|
-
let previous = userInfo[CompactBlockProcessorNotificationKey.previousConnectivityStatus] as? ConnectivityState,
|
|
329
|
-
let current = userInfo[CompactBlockProcessorNotificationKey.currentConnectivityStatus] as? ConnectivityState
|
|
330
|
-
else {
|
|
331
|
-
LoggerProxy.error(
|
|
332
|
-
"Found \(Notification.Name.blockProcessorConnectivityStateChanged) but lacks dictionary information." +
|
|
333
|
-
"This is probably a programming error"
|
|
334
|
-
)
|
|
335
|
-
return
|
|
115
|
+
|
|
116
|
+
func checkIfCanContinueInitialisation() -> ZcashError? {
|
|
117
|
+
if let initialisationError = initializer.urlsParsingError {
|
|
118
|
+
return initialisationError
|
|
336
119
|
}
|
|
337
120
|
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
name: .synchronizerConnectionStateChanged,
|
|
341
|
-
object: self,
|
|
342
|
-
userInfo: [
|
|
343
|
-
NotificationKeys.previousConnectionState: ConnectionState(previous),
|
|
344
|
-
NotificationKeys.currentConnectionState: currentState
|
|
345
|
-
]
|
|
346
|
-
)
|
|
347
|
-
|
|
348
|
-
DispatchQueue.main.async { [weak self] in
|
|
349
|
-
self?.connectionState = currentState
|
|
121
|
+
if !UsedAliasesChecker.tryToUse(alias: initializer.alias, id: initializer.id) {
|
|
122
|
+
return .initializerAliasAlreadyInUse(initializer.alias)
|
|
350
123
|
}
|
|
124
|
+
|
|
125
|
+
return nil
|
|
351
126
|
}
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
127
|
+
|
|
128
|
+
public func prepare(
|
|
129
|
+
with seed: [UInt8]?,
|
|
130
|
+
viewingKeys: [UnifiedFullViewingKey],
|
|
131
|
+
walletBirthday: BlockHeight
|
|
132
|
+
) async throws -> Initializer.InitializationResult {
|
|
133
|
+
guard await status == .unprepared else { return .success }
|
|
134
|
+
|
|
135
|
+
if let error = checkIfCanContinueInitialisation() {
|
|
136
|
+
throw error
|
|
359
137
|
}
|
|
360
138
|
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
NotificationKeys.foundTransactions: foundTransactions
|
|
366
|
-
]
|
|
367
|
-
)
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
@objc func reorgDetected(_ notification: Notification) {
|
|
371
|
-
guard
|
|
372
|
-
let userInfo = notification.userInfo,
|
|
373
|
-
let progress = userInfo[CompactBlockProcessorNotificationKey.reorgHeight] as? BlockHeight,
|
|
374
|
-
let rewindHeight = userInfo[CompactBlockProcessorNotificationKey.rewindHeight] as? BlockHeight
|
|
375
|
-
else {
|
|
376
|
-
LoggerProxy.debug("error processing reorg notification")
|
|
377
|
-
return
|
|
139
|
+
try await utxoRepository.initialise()
|
|
140
|
+
|
|
141
|
+
if case .seedRequired = try await self.initializer.initialize(with: seed, viewingKeys: viewingKeys, walletBirthday: walletBirthday) {
|
|
142
|
+
return .seedRequired
|
|
378
143
|
}
|
|
144
|
+
|
|
145
|
+
await latestBlocksDataProvider.updateWalletBirthday(initializer.walletBirthday)
|
|
146
|
+
await latestBlocksDataProvider.updateScannedData()
|
|
379
147
|
|
|
380
|
-
|
|
148
|
+
await updateStatus(.disconnected)
|
|
381
149
|
|
|
382
|
-
|
|
383
|
-
try transactionManager.handleReorg(at: rewindHeight)
|
|
384
|
-
} catch {
|
|
385
|
-
LoggerProxy.debug("error handling reorg: \(error)")
|
|
386
|
-
notifyFailure(error)
|
|
387
|
-
}
|
|
150
|
+
return .success
|
|
388
151
|
}
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
152
|
+
|
|
153
|
+
/// Starts the synchronizer
|
|
154
|
+
/// - Throws: ZcashError when failures occur
|
|
155
|
+
public func start(retry: Bool = false) async throws {
|
|
156
|
+
switch await status {
|
|
157
|
+
case .unprepared:
|
|
158
|
+
throw ZcashError.synchronizerNotPrepared
|
|
159
|
+
|
|
160
|
+
case .syncing, .enhancing, .fetching:
|
|
161
|
+
logger.warn("warning: Synchronizer started when already running. Next sync process will be started when the current one stops.")
|
|
162
|
+
/// This may look strange but `CompactBlockProcessor` has mechanisms which can handle this situation. So we are fine with calling
|
|
163
|
+
/// it's start here.
|
|
164
|
+
await blockProcessor.start(retry: retry)
|
|
165
|
+
|
|
166
|
+
case .stopped, .synced, .disconnected, .error:
|
|
167
|
+
await updateStatus(.syncing(.nullProgress))
|
|
168
|
+
syncStartDate = Date()
|
|
169
|
+
await blockProcessor.start(retry: retry)
|
|
396
170
|
}
|
|
397
|
-
|
|
398
|
-
self.notify(progress: progress)
|
|
399
171
|
}
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
172
|
+
|
|
173
|
+
/// Stops the synchronizer
|
|
174
|
+
public func stop() {
|
|
175
|
+
// Calling `await blockProcessor.stop()` make take some time. If the downloading of blocks is in progress then this method inside waits until
|
|
176
|
+
// downloading is really done. Which could block execution of the code on the client side. So it's better strategy to spin up new task and
|
|
177
|
+
// exit fast on client side.
|
|
178
|
+
Task(priority: .high) {
|
|
179
|
+
let status = await self.status
|
|
180
|
+
guard status != .stopped, status != .disconnected else {
|
|
181
|
+
logger.info("attempted to stop when status was: \(status)")
|
|
182
|
+
return
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
await blockProcessor.stop()
|
|
405
186
|
}
|
|
406
187
|
}
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
188
|
+
|
|
189
|
+
// MARK: Connectivity State
|
|
190
|
+
|
|
191
|
+
func connectivityStateChanged(oldState: ConnectionState, newState: ConnectionState) {
|
|
192
|
+
connectionState = newState
|
|
193
|
+
streamsUpdateQueue.async { [weak self] in
|
|
194
|
+
self?.eventSubject.send(.connectionStateChanged(newState))
|
|
412
195
|
}
|
|
413
196
|
}
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
197
|
+
|
|
198
|
+
// MARK: Handle CompactBlockProcessor.Flow
|
|
199
|
+
|
|
200
|
+
// swiftlint:disable:next cyclomatic_complexity
|
|
201
|
+
private func subscribeToProcessorEvents(_ processor: CompactBlockProcessor) async {
|
|
202
|
+
let eventClosure: CompactBlockProcessor.EventClosure = { [weak self] event in
|
|
203
|
+
switch event {
|
|
204
|
+
case let .failed(error):
|
|
205
|
+
await self?.failed(error: error)
|
|
206
|
+
|
|
207
|
+
case let .finished(height, foundBlocks):
|
|
208
|
+
await self?.finished(lastScannedHeight: height, foundBlocks: foundBlocks)
|
|
209
|
+
|
|
210
|
+
case let .foundTransactions(transactions, range):
|
|
211
|
+
self?.foundTransactions(transactions: transactions, in: range)
|
|
212
|
+
|
|
213
|
+
case let .handledReorg(reorgHeight, rewindHeight):
|
|
214
|
+
// log reorg information
|
|
215
|
+
self?.logger.info("handling reorg at: \(reorgHeight) with rewind height: \(rewindHeight)")
|
|
216
|
+
|
|
217
|
+
case let .progressUpdated(progress):
|
|
218
|
+
await self?.progressUpdated(progress: progress)
|
|
219
|
+
|
|
220
|
+
case let .storedUTXOs(utxos):
|
|
221
|
+
self?.storedUTXOs(utxos: utxos)
|
|
222
|
+
|
|
223
|
+
case .startedEnhancing:
|
|
224
|
+
await self?.updateStatus(.enhancing(.zero))
|
|
225
|
+
|
|
226
|
+
case .startedFetching:
|
|
227
|
+
await self?.updateStatus(.fetching(0))
|
|
228
|
+
|
|
229
|
+
case .startedSyncing:
|
|
230
|
+
await self?.updateStatus(.syncing(.nullProgress))
|
|
231
|
+
|
|
232
|
+
case .stopped:
|
|
233
|
+
await self?.updateStatus(.stopped)
|
|
234
|
+
|
|
235
|
+
case .minedTransaction(let transaction):
|
|
236
|
+
self?.notifyMinedTransaction(transaction)
|
|
237
|
+
}
|
|
419
238
|
}
|
|
239
|
+
|
|
240
|
+
await processor.updateEventClosure(identifier: "SDKSynchronizer", closure: eventClosure)
|
|
420
241
|
}
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
self.status = .enhancing(NullEnhancementProgress())
|
|
425
|
-
}
|
|
242
|
+
|
|
243
|
+
private func failed(error: Error) async {
|
|
244
|
+
await updateStatus(.error(error))
|
|
426
245
|
}
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
246
|
+
|
|
247
|
+
private func finished(lastScannedHeight: BlockHeight, foundBlocks: Bool) async {
|
|
248
|
+
await latestBlocksDataProvider.updateScannedData()
|
|
249
|
+
|
|
250
|
+
await updateStatus(.synced)
|
|
251
|
+
|
|
252
|
+
if let syncStartDate {
|
|
253
|
+
metrics.pushSyncReport(
|
|
254
|
+
start: syncStartDate,
|
|
255
|
+
end: Date()
|
|
256
|
+
)
|
|
432
257
|
}
|
|
433
258
|
}
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
self.status = .stopped
|
|
259
|
+
|
|
260
|
+
private func foundTransactions(transactions: [ZcashTransaction.Overview], in range: CompactBlockRange) {
|
|
261
|
+
streamsUpdateQueue.async { [weak self] in
|
|
262
|
+
self?.eventSubject.send(.foundTransactions(transactions, range))
|
|
439
263
|
}
|
|
440
264
|
}
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
if let error = notification.userInfo?[CompactBlockProcessorNotificationKey.error] as? Error {
|
|
446
|
-
self.notifyFailure(error)
|
|
447
|
-
self.status = .error(self.mapError(error))
|
|
448
|
-
} else {
|
|
449
|
-
self.notifyFailure(
|
|
450
|
-
CompactBlockProcessorError.generalError(
|
|
451
|
-
message: "This is strange. processorFailed Call received no error message"
|
|
452
|
-
)
|
|
453
|
-
)
|
|
454
|
-
self.status = .error(SynchronizerError.generalError(message: "This is strange. processorFailed Call received no error message"))
|
|
455
|
-
}
|
|
456
|
-
}
|
|
265
|
+
|
|
266
|
+
private func progressUpdated(progress: CompactBlockProgress) async {
|
|
267
|
+
let newStatus = InternalSyncStatus(progress)
|
|
268
|
+
await updateStatus(newStatus)
|
|
457
269
|
}
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
self.status = .disconnected
|
|
270
|
+
|
|
271
|
+
private func storedUTXOs(utxos: (inserted: [UnspentTransactionOutputEntity], skipped: [UnspentTransactionOutputEntity])) {
|
|
272
|
+
streamsUpdateQueue.async { [weak self] in
|
|
273
|
+
self?.eventSubject.send(.storedUTXOs(utxos.inserted, utxos.skipped))
|
|
463
274
|
}
|
|
464
275
|
}
|
|
465
|
-
|
|
466
|
-
@objc func processorFinished(_ notification: Notification) {
|
|
467
|
-
// FIX: Pending transaction updates fail if done from another thread. Improvement needed: explicitly define queues for sql repositories
|
|
468
|
-
|
|
469
|
-
DispatchQueue.main.async { [weak self] in
|
|
470
|
-
guard let self = self else { return }
|
|
471
|
-
if let blockHeight = notification.userInfo?[CompactBlockProcessorNotificationKey.latestScannedBlockHeight] as? BlockHeight {
|
|
472
|
-
self.latestScannedHeight = blockHeight
|
|
473
|
-
}
|
|
474
|
-
self.refreshPendingTransactions()
|
|
475
|
-
self.status = .synced
|
|
476
|
-
}
|
|
477
|
-
}
|
|
478
|
-
|
|
479
|
-
@objc func processorTransitionUnknown(_ notification: Notification) {
|
|
480
|
-
self.status = .disconnected
|
|
481
|
-
}
|
|
482
|
-
|
|
276
|
+
|
|
483
277
|
// MARK: Synchronizer methods
|
|
484
278
|
|
|
485
|
-
// swiftlint:disable:next function_parameter_count
|
|
486
279
|
public func sendToAddress(
|
|
487
|
-
spendingKey:
|
|
488
|
-
zatoshi:
|
|
489
|
-
toAddress:
|
|
490
|
-
memo:
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
switch downloadResult {
|
|
497
|
-
case .success:
|
|
498
|
-
self?.createToAddress(
|
|
499
|
-
spendingKey: spendingKey,
|
|
500
|
-
zatoshi: zatoshi,
|
|
501
|
-
toAddress: toAddress,
|
|
502
|
-
memo: memo,
|
|
503
|
-
from: accountIndex,
|
|
504
|
-
resultBlock: resultBlock
|
|
505
|
-
)
|
|
506
|
-
case .failure(let error):
|
|
507
|
-
resultBlock(.failure(SynchronizerError.parameterMissing(underlyingError: error)))
|
|
508
|
-
}
|
|
509
|
-
}
|
|
280
|
+
spendingKey: UnifiedSpendingKey,
|
|
281
|
+
zatoshi: Zatoshi,
|
|
282
|
+
toAddress: Recipient,
|
|
283
|
+
memo: Memo?
|
|
284
|
+
) async throws -> ZcashTransaction.Overview {
|
|
285
|
+
try throwIfUnprepared()
|
|
286
|
+
|
|
287
|
+
if case Recipient.transparent = toAddress, memo != nil {
|
|
288
|
+
throw ZcashError.synchronizerSendMemoToTransparentAddress
|
|
510
289
|
}
|
|
290
|
+
|
|
291
|
+
try await SaplingParameterDownloader.downloadParamsIfnotPresent(
|
|
292
|
+
spendURL: initializer.spendParamsURL,
|
|
293
|
+
spendSourceURL: initializer.saplingParamsSourceURL.spendParamFileURL,
|
|
294
|
+
outputURL: initializer.outputParamsURL,
|
|
295
|
+
outputSourceURL: initializer.saplingParamsSourceURL.outputParamFileURL,
|
|
296
|
+
logger: logger
|
|
297
|
+
)
|
|
298
|
+
|
|
299
|
+
return try await createToAddress(
|
|
300
|
+
spendingKey: spendingKey,
|
|
301
|
+
zatoshi: zatoshi,
|
|
302
|
+
recipient: toAddress,
|
|
303
|
+
memo: memo
|
|
304
|
+
)
|
|
511
305
|
}
|
|
512
|
-
|
|
306
|
+
|
|
513
307
|
public func shieldFunds(
|
|
514
|
-
spendingKey:
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
308
|
+
spendingKey: UnifiedSpendingKey,
|
|
309
|
+
memo: Memo,
|
|
310
|
+
shieldingThreshold: Zatoshi
|
|
311
|
+
) async throws -> ZcashTransaction.Overview {
|
|
312
|
+
try throwIfUnprepared()
|
|
313
|
+
|
|
520
314
|
// let's see if there are funds to shield
|
|
521
|
-
let
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
// Verify that at least there are funds for the fee. Ideally this logic will be improved by the shielding wallet.
|
|
528
|
-
guard tBalance.verified >= self.network.constants.defaultFee(for: self.latestScannedHeight) else {
|
|
529
|
-
resultBlock(.failure(ShieldFundsError.insuficientTransparentFunds))
|
|
530
|
-
return
|
|
531
|
-
}
|
|
532
|
-
let viewingKey = try derivationTool.deriveViewingKey(spendingKey: spendingKey)
|
|
533
|
-
let zAddr = try derivationTool.deriveShieldedAddress(viewingKey: viewingKey)
|
|
534
|
-
|
|
535
|
-
let shieldingSpend = try transactionManager.initSpend(zatoshi: Int(tBalance.verified), toAddress: zAddr, memo: memo, from: 0)
|
|
536
|
-
|
|
537
|
-
transactionManager.encodeShieldingTransaction(
|
|
538
|
-
spendingKey: spendingKey,
|
|
539
|
-
tsk: transparentSecretKey,
|
|
540
|
-
pendingTransaction: shieldingSpend
|
|
541
|
-
) { [weak self] result in
|
|
542
|
-
guard let self = self else { return }
|
|
543
|
-
|
|
544
|
-
switch result {
|
|
545
|
-
case .success(let transaction):
|
|
546
|
-
self.transactionManager.submit(pendingTransaction: transaction) { submitResult in
|
|
547
|
-
switch submitResult {
|
|
548
|
-
case .success(let submittedTx):
|
|
549
|
-
resultBlock(.success(submittedTx))
|
|
550
|
-
case .failure(let submissionError):
|
|
551
|
-
DispatchQueue.main.async {
|
|
552
|
-
resultBlock(.failure(submissionError))
|
|
553
|
-
}
|
|
554
|
-
}
|
|
555
|
-
}
|
|
556
|
-
|
|
557
|
-
case .failure(let error):
|
|
558
|
-
resultBlock(.failure(error))
|
|
559
|
-
}
|
|
560
|
-
}
|
|
561
|
-
} catch {
|
|
562
|
-
resultBlock(.failure(error))
|
|
563
|
-
return
|
|
315
|
+
let accountIndex = Int(spendingKey.account)
|
|
316
|
+
let tBalance = try await self.getTransparentBalance(accountIndex: accountIndex)
|
|
317
|
+
|
|
318
|
+
// Verify that at least there are funds for the fee. Ideally this logic will be improved by the shielding wallet.
|
|
319
|
+
guard tBalance.verified >= self.network.constants.defaultFee(for: await self.latestBlocksDataProvider.latestScannedHeight) else {
|
|
320
|
+
throw ZcashError.synchronizerShieldFundsInsuficientTransparentFunds
|
|
564
321
|
}
|
|
322
|
+
|
|
323
|
+
let transaction = try await transactionEncoder.createShieldingTransaction(
|
|
324
|
+
spendingKey: spendingKey,
|
|
325
|
+
shieldingThreshold: shieldingThreshold,
|
|
326
|
+
memoBytes: memo.asMemoBytes(),
|
|
327
|
+
from: Int(spendingKey.account)
|
|
328
|
+
)
|
|
329
|
+
|
|
330
|
+
let encodedTx = try transaction.encodedTransaction()
|
|
331
|
+
|
|
332
|
+
try await transactionEncoder.submit(transaction: encodedTx)
|
|
333
|
+
|
|
334
|
+
return transaction
|
|
565
335
|
}
|
|
566
336
|
|
|
567
|
-
// swiftlint:disable:next function_parameter_count
|
|
568
337
|
func createToAddress(
|
|
569
|
-
spendingKey:
|
|
570
|
-
zatoshi:
|
|
571
|
-
|
|
572
|
-
memo:
|
|
573
|
-
|
|
574
|
-
resultBlock: @escaping (Result<PendingTransactionEntity, Error>) -> Void
|
|
575
|
-
) {
|
|
338
|
+
spendingKey: UnifiedSpendingKey,
|
|
339
|
+
zatoshi: Zatoshi,
|
|
340
|
+
recipient: Recipient,
|
|
341
|
+
memo: Memo?
|
|
342
|
+
) async throws -> ZcashTransaction.Overview {
|
|
576
343
|
do {
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
344
|
+
if
|
|
345
|
+
case .transparent = recipient,
|
|
346
|
+
memo != nil {
|
|
347
|
+
throw ZcashError.synchronizerSendMemoToTransparentAddress
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
let transaction = try await transactionEncoder.createTransaction(
|
|
351
|
+
spendingKey: spendingKey,
|
|
352
|
+
zatoshi: zatoshi,
|
|
353
|
+
to: recipient.stringEncoded,
|
|
354
|
+
memoBytes: memo?.asMemoBytes(),
|
|
355
|
+
from: Int(spendingKey.account)
|
|
582
356
|
)
|
|
357
|
+
|
|
358
|
+
let encodedTransaction = try transaction.encodedTransaction()
|
|
359
|
+
|
|
360
|
+
try await transactionEncoder.submit(transaction: encodedTransaction)
|
|
583
361
|
|
|
584
|
-
|
|
585
|
-
guard let self = self else { return }
|
|
586
|
-
switch result {
|
|
587
|
-
case .success(let transaction):
|
|
588
|
-
self.transactionManager.submit(pendingTransaction: transaction) { submitResult in
|
|
589
|
-
switch submitResult {
|
|
590
|
-
case .success(let submittedTx):
|
|
591
|
-
resultBlock(.success(submittedTx))
|
|
592
|
-
case .failure(let submissionError):
|
|
593
|
-
DispatchQueue.main.async {
|
|
594
|
-
resultBlock(.failure(submissionError))
|
|
595
|
-
}
|
|
596
|
-
}
|
|
597
|
-
}
|
|
598
|
-
|
|
599
|
-
case .failure(let error):
|
|
600
|
-
resultBlock(.failure(error))
|
|
601
|
-
}
|
|
602
|
-
}
|
|
362
|
+
return transaction
|
|
603
363
|
} catch {
|
|
604
|
-
|
|
364
|
+
throw error
|
|
605
365
|
}
|
|
606
366
|
}
|
|
607
|
-
|
|
608
|
-
public func
|
|
609
|
-
|
|
610
|
-
}
|
|
611
|
-
|
|
612
|
-
public func allReceivedTransactions() throws -> [ConfirmedTransactionEntity] {
|
|
613
|
-
try transactionRepository.findAllReceivedTransactions(offset: 0, limit: Int.max) ?? [ConfirmedTransactionEntity]()
|
|
367
|
+
|
|
368
|
+
public func allReceivedTransactions() async throws -> [ZcashTransaction.Overview] {
|
|
369
|
+
try await transactionRepository.findReceived(offset: 0, limit: Int.max)
|
|
614
370
|
}
|
|
615
|
-
|
|
616
|
-
public func allPendingTransactions() throws -> [
|
|
617
|
-
|
|
371
|
+
|
|
372
|
+
public func allPendingTransactions() async throws -> [ZcashTransaction.Overview] {
|
|
373
|
+
let latestScannedHeight = self.latestState.latestScannedHeight
|
|
374
|
+
|
|
375
|
+
return try await transactionRepository.findPendingTransactions(latestHeight: latestScannedHeight, offset: 0, limit: .max)
|
|
618
376
|
}
|
|
619
|
-
|
|
620
|
-
public func
|
|
621
|
-
try transactionRepository.
|
|
377
|
+
|
|
378
|
+
public func allTransactions() async throws -> [ZcashTransaction.Overview] {
|
|
379
|
+
return try await transactionRepository.find(offset: 0, limit: Int.max, kind: .all)
|
|
622
380
|
}
|
|
623
|
-
|
|
624
|
-
public func allSentTransactions() throws -> [
|
|
625
|
-
try transactionRepository.
|
|
381
|
+
|
|
382
|
+
public func allSentTransactions() async throws -> [ZcashTransaction.Overview] {
|
|
383
|
+
return try await transactionRepository.findSent(offset: 0, limit: Int.max)
|
|
626
384
|
}
|
|
627
|
-
|
|
628
|
-
public func
|
|
629
|
-
try transactionRepository.
|
|
385
|
+
|
|
386
|
+
public func allTransactions(from transaction: ZcashTransaction.Overview, limit: Int) async throws -> [ZcashTransaction.Overview] {
|
|
387
|
+
return try await transactionRepository.find(from: transaction, limit: limit, kind: .all)
|
|
630
388
|
}
|
|
631
|
-
|
|
389
|
+
|
|
632
390
|
public func paginatedTransactions(of kind: TransactionKind = .all) -> PaginatedTransactionRepository {
|
|
633
391
|
PagedTransactionRepositoryBuilder.build(initializer: initializer, kind: .all)
|
|
634
392
|
}
|
|
635
|
-
|
|
636
|
-
public func
|
|
637
|
-
try
|
|
393
|
+
|
|
394
|
+
public func getMemos(for transaction: ZcashTransaction.Overview) async throws -> [Memo] {
|
|
395
|
+
return try await transactionRepository.findMemos(for: transaction)
|
|
638
396
|
}
|
|
639
|
-
|
|
640
|
-
public func
|
|
641
|
-
|
|
397
|
+
|
|
398
|
+
public func getRecipients(for transaction: ZcashTransaction.Overview) async -> [TransactionRecipient] {
|
|
399
|
+
return (try? await transactionRepository.getRecipients(for: transaction.id)) ?? []
|
|
642
400
|
}
|
|
643
|
-
|
|
644
|
-
public func
|
|
645
|
-
try
|
|
401
|
+
|
|
402
|
+
public func getTransactionOutputs(for transaction: ZcashTransaction.Overview) async -> [ZcashTransaction.Output] {
|
|
403
|
+
return (try? await transactionRepository.getTransactionOutputs(for: transaction.id)) ?? []
|
|
646
404
|
}
|
|
647
|
-
|
|
648
|
-
public func
|
|
405
|
+
|
|
406
|
+
public func latestHeight() async throws -> BlockHeight {
|
|
407
|
+
try await blockProcessor.blockDownloaderService.latestBlockHeight()
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
public func latestUTXOs(address: String) async throws -> [UnspentTransactionOutputEntity] {
|
|
411
|
+
try throwIfUnprepared()
|
|
412
|
+
|
|
649
413
|
guard initializer.isValidTransparentAddress(address) else {
|
|
650
|
-
|
|
651
|
-
return
|
|
414
|
+
throw ZcashError.synchronizerLatestUTXOsInvalidTAddress
|
|
652
415
|
}
|
|
653
416
|
|
|
654
|
-
initializer.lightWalletService.fetchUTXOs(for: address, height: network.constants.saplingActivationHeight)
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
try self.utxoRepository.store(utxos: utxos)
|
|
661
|
-
result(.success(utxos))
|
|
662
|
-
} catch {
|
|
663
|
-
result(.failure(SynchronizerError.generalError(message: "\(error)")))
|
|
664
|
-
}
|
|
665
|
-
case .failure(let error):
|
|
666
|
-
result(.failure(SynchronizerError.connectionFailed(message: error)))
|
|
667
|
-
}
|
|
417
|
+
let stream = initializer.lightWalletService.fetchUTXOs(for: address, height: network.constants.saplingActivationHeight)
|
|
418
|
+
|
|
419
|
+
// swiftlint:disable:next array_constructor
|
|
420
|
+
var utxos: [UnspentTransactionOutputEntity] = []
|
|
421
|
+
for try await transactionEntity in stream {
|
|
422
|
+
utxos.append(transactionEntity)
|
|
668
423
|
}
|
|
424
|
+
try await self.utxoRepository.clearAll(address: address)
|
|
425
|
+
try await self.utxoRepository.store(utxos: utxos)
|
|
426
|
+
return utxos
|
|
669
427
|
}
|
|
670
|
-
|
|
671
|
-
public func refreshUTXOs(address:
|
|
672
|
-
|
|
428
|
+
|
|
429
|
+
public func refreshUTXOs(address: TransparentAddress, from height: BlockHeight) async throws -> RefreshedUTXOs {
|
|
430
|
+
try throwIfUnprepared()
|
|
431
|
+
return try await blockProcessor.refreshUTXOs(tAddress: address, startHeight: height)
|
|
673
432
|
}
|
|
674
|
-
|
|
675
|
-
public func getShieldedBalance(accountIndex: Int = 0) ->
|
|
676
|
-
initializer.getBalance(account: accountIndex)
|
|
433
|
+
|
|
434
|
+
public func getShieldedBalance(accountIndex: Int = 0) async throws -> Zatoshi {
|
|
435
|
+
let balance = try await initializer.rustBackend.getBalance(account: Int32(accountIndex))
|
|
436
|
+
|
|
437
|
+
return Zatoshi(balance)
|
|
677
438
|
}
|
|
678
|
-
|
|
679
|
-
public func getShieldedVerifiedBalance(accountIndex: Int = 0) ->
|
|
680
|
-
initializer.getVerifiedBalance(account: accountIndex)
|
|
439
|
+
|
|
440
|
+
public func getShieldedVerifiedBalance(accountIndex: Int = 0) async throws -> Zatoshi {
|
|
441
|
+
let balance = try await initializer.rustBackend.getVerifiedBalance(account: Int32(accountIndex))
|
|
442
|
+
|
|
443
|
+
return Zatoshi(balance)
|
|
681
444
|
}
|
|
682
|
-
|
|
683
|
-
public func
|
|
684
|
-
blockProcessor.
|
|
445
|
+
|
|
446
|
+
public func getUnifiedAddress(accountIndex: Int) async throws -> UnifiedAddress {
|
|
447
|
+
try await blockProcessor.getUnifiedAddress(accountIndex: accountIndex)
|
|
685
448
|
}
|
|
686
|
-
|
|
687
|
-
public func
|
|
688
|
-
blockProcessor.
|
|
449
|
+
|
|
450
|
+
public func getSaplingAddress(accountIndex: Int) async throws -> SaplingAddress {
|
|
451
|
+
try await blockProcessor.getSaplingAddress(accountIndex: accountIndex)
|
|
689
452
|
}
|
|
690
|
-
|
|
691
|
-
public func getTransparentAddress(accountIndex: Int) -> TransparentAddress
|
|
692
|
-
blockProcessor.getTransparentAddress(accountIndex: accountIndex)
|
|
453
|
+
|
|
454
|
+
public func getTransparentAddress(accountIndex: Int) async throws -> TransparentAddress {
|
|
455
|
+
try await blockProcessor.getTransparentAddress(accountIndex: accountIndex)
|
|
693
456
|
}
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
457
|
+
|
|
458
|
+
/// Returns the last stored transparent balance
|
|
459
|
+
public func getTransparentBalance(accountIndex: Int) async throws -> WalletBalance {
|
|
460
|
+
try await blockProcessor.getTransparentBalance(accountIndex: accountIndex)
|
|
697
461
|
}
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
462
|
+
|
|
463
|
+
// MARK: Rewind
|
|
464
|
+
|
|
465
|
+
public func rewind(_ policy: RewindPolicy) -> AnyPublisher<Void, Error> {
|
|
466
|
+
let subject = PassthroughSubject<Void, Error>()
|
|
467
|
+
Task(priority: .high) {
|
|
468
|
+
if !latestState.internalSyncStatus.isPrepared {
|
|
469
|
+
subject.send(completion: .failure(ZcashError.synchronizerNotPrepared))
|
|
470
|
+
return
|
|
471
|
+
}
|
|
472
|
+
|
|
473
|
+
let height: BlockHeight?
|
|
474
|
+
|
|
475
|
+
switch policy {
|
|
476
|
+
case .quick:
|
|
477
|
+
height = nil
|
|
478
|
+
|
|
479
|
+
case .birthday:
|
|
480
|
+
let birthday = await self.blockProcessor.config.walletBirthday
|
|
481
|
+
height = birthday
|
|
482
|
+
|
|
483
|
+
case .height(let rewindHeight):
|
|
484
|
+
height = rewindHeight
|
|
485
|
+
|
|
486
|
+
case .transaction(let transaction):
|
|
487
|
+
guard let txHeight = transaction.anchor(network: self.network) else {
|
|
488
|
+
throw ZcashError.synchronizerRewindUnknownArchorHeight
|
|
489
|
+
}
|
|
490
|
+
height = txHeight
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
let context = AfterSyncHooksManager.RewindContext(
|
|
494
|
+
height: height,
|
|
495
|
+
completion: { result in
|
|
496
|
+
switch result {
|
|
497
|
+
case .success:
|
|
498
|
+
subject.send(completion: .finished)
|
|
499
|
+
|
|
500
|
+
case let .failure(error):
|
|
501
|
+
subject.send(completion: .failure(error))
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
)
|
|
505
|
+
|
|
506
|
+
await blockProcessor.rewind(context: context)
|
|
707
507
|
}
|
|
508
|
+
return subject.eraseToAnyPublisher()
|
|
708
509
|
}
|
|
709
|
-
|
|
710
|
-
public func rewind(_ policy: RewindPolicy) throws {
|
|
711
|
-
self.stop()
|
|
712
|
-
|
|
713
|
-
var height: BlockHeight?
|
|
714
|
-
|
|
715
|
-
switch policy {
|
|
716
|
-
case .quick:
|
|
717
|
-
break
|
|
718
510
|
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
guard let txHeight = transaction.anchor(network: self.network) else {
|
|
728
|
-
throw SynchronizerError.rewindErrorUnknownArchorHeight
|
|
511
|
+
// MARK: Wipe
|
|
512
|
+
|
|
513
|
+
public func wipe() -> AnyPublisher<Void, Error> {
|
|
514
|
+
let subject = PassthroughSubject<Void, Error>()
|
|
515
|
+
Task(priority: .high) {
|
|
516
|
+
if let error = checkIfCanContinueInitialisation() {
|
|
517
|
+
subject.send(completion: .failure(error))
|
|
518
|
+
return
|
|
729
519
|
}
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
520
|
+
|
|
521
|
+
let context = AfterSyncHooksManager.WipeContext(
|
|
522
|
+
prewipe: { [weak self] in
|
|
523
|
+
self?.transactionEncoder.closeDBConnection()
|
|
524
|
+
self?.transactionRepository.closeDBConnection()
|
|
525
|
+
},
|
|
526
|
+
completion: { [weak self] possibleError in
|
|
527
|
+
await self?.updateStatus(.unprepared)
|
|
528
|
+
if let error = possibleError {
|
|
529
|
+
subject.send(completion: .failure(error))
|
|
530
|
+
} else {
|
|
531
|
+
subject.send(completion: .finished)
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
)
|
|
535
|
+
|
|
536
|
+
await blockProcessor.wipe(context: context)
|
|
738
537
|
}
|
|
538
|
+
|
|
539
|
+
return subject.eraseToAnyPublisher()
|
|
739
540
|
}
|
|
740
|
-
|
|
541
|
+
|
|
741
542
|
// MARK: notify state
|
|
742
|
-
private func notify(progress: CompactBlockProgress) {
|
|
743
|
-
var userInfo: [AnyHashable: Any] = .init()
|
|
744
|
-
userInfo[NotificationKeys.progress] = progress
|
|
745
|
-
userInfo[NotificationKeys.blockHeight] = progress.progressHeight
|
|
746
543
|
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
]
|
|
544
|
+
private func snapshotState(status: InternalSyncStatus) async -> SynchronizerState {
|
|
545
|
+
return await SynchronizerState(
|
|
546
|
+
syncSessionID: syncSession.value,
|
|
547
|
+
shieldedBalance: WalletBalance(
|
|
548
|
+
verified: (try? await getShieldedVerifiedBalance()) ?? .zero,
|
|
549
|
+
total: (try? await getShieldedBalance()) ?? .zero
|
|
550
|
+
),
|
|
551
|
+
transparentBalance: (try? await blockProcessor.getTransparentBalance(accountIndex: 0)) ?? .zero,
|
|
552
|
+
internalSyncStatus: status,
|
|
553
|
+
latestScannedHeight: latestBlocksDataProvider.latestScannedHeight,
|
|
554
|
+
latestBlockHeight: latestBlocksDataProvider.latestBlockHeight,
|
|
555
|
+
latestScannedTime: latestBlocksDataProvider.latestScannedTime
|
|
760
556
|
)
|
|
761
557
|
}
|
|
762
|
-
|
|
763
|
-
private func notify(status: SyncStatus) {
|
|
764
|
-
switch status {
|
|
765
|
-
case .disconnected:
|
|
766
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerDisconnected, object: self)
|
|
767
|
-
case .stopped:
|
|
768
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerStopped, object: self)
|
|
769
|
-
case .synced:
|
|
770
|
-
NotificationCenter.default.post(
|
|
771
|
-
name: Notification.Name.synchronizerSynced,
|
|
772
|
-
object: self,
|
|
773
|
-
userInfo: [
|
|
774
|
-
SDKSynchronizer.NotificationKeys.blockHeight: self.latestScannedHeight
|
|
775
|
-
]
|
|
776
|
-
)
|
|
777
|
-
case .unprepared:
|
|
778
|
-
break
|
|
779
|
-
case .downloading:
|
|
780
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerDownloading, object: self)
|
|
781
|
-
case .validating:
|
|
782
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerValidating, object: self)
|
|
783
|
-
case .scanning:
|
|
784
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerScanning, object: self)
|
|
785
|
-
case .enhancing:
|
|
786
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerEnhancing, object: self)
|
|
787
|
-
case .fetching:
|
|
788
|
-
NotificationCenter.default.post(name: Notification.Name.synchronizerFetching, object: self)
|
|
789
|
-
case .error(let e):
|
|
790
|
-
self.notifyFailure(e)
|
|
791
|
-
}
|
|
792
|
-
}
|
|
793
|
-
// MARK: book keeping
|
|
794
|
-
|
|
795
|
-
private func updateMinedTransactions() throws {
|
|
796
|
-
try transactionManager.allPendingTransactions()?
|
|
797
|
-
.filter { $0.isSubmitSuccess && !$0.isMined }
|
|
798
|
-
.forEach { pendingTx in
|
|
799
|
-
guard let rawId = pendingTx.rawTransactionId else { return }
|
|
800
|
-
let transaction = try transactionRepository.findBy(rawId: rawId)
|
|
801
558
|
|
|
802
|
-
|
|
803
|
-
|
|
559
|
+
private func notify(oldStatus: InternalSyncStatus, newStatus: InternalSyncStatus) async {
|
|
560
|
+
guard oldStatus != newStatus else { return }
|
|
561
|
+
|
|
562
|
+
let newState: SynchronizerState
|
|
563
|
+
|
|
564
|
+
// When the wipe happens status is switched to `unprepared`. And we expect that everything is deleted. All the databases including data DB.
|
|
565
|
+
// When new snapshot is created balance is checked. And when balance is checked and data DB doesn't exist then rust initialise new database.
|
|
566
|
+
// So it's necessary to not create new snapshot after status is switched to `unprepared` otherwise data DB exists after wipe
|
|
567
|
+
if newStatus == .unprepared {
|
|
568
|
+
var nextState = SynchronizerState.zero
|
|
804
569
|
|
|
805
|
-
|
|
570
|
+
let nextSessionID = await self.syncSession.update(.nullID)
|
|
571
|
+
|
|
572
|
+
nextState.syncSessionID = nextSessionID
|
|
573
|
+
newState = nextState
|
|
574
|
+
} else {
|
|
575
|
+
if SessionTicker.live.isNewSyncSession(oldStatus, newStatus) {
|
|
576
|
+
await self.syncSession.newSession(with: self.syncSessionIDGenerator)
|
|
806
577
|
}
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
private func removeConfirmedTransactions() throws {
|
|
810
|
-
let latestHeight = try transactionRepository.lastScannedHeight()
|
|
811
|
-
|
|
812
|
-
try transactionManager.allPendingTransactions()?
|
|
813
|
-
.filter { $0.minedHeight > 0 && abs($0.minedHeight - latestHeight) >= ZcashSDK.defaultStaleTolerance }
|
|
814
|
-
.forEach { try transactionManager.delete(pendingTransaction: $0) }
|
|
815
|
-
}
|
|
816
|
-
|
|
817
|
-
private func refreshPendingTransactions() {
|
|
818
|
-
do {
|
|
819
|
-
try updateMinedTransactions()
|
|
820
|
-
try removeConfirmedTransactions()
|
|
821
|
-
} catch {
|
|
822
|
-
LoggerProxy.debug("error refreshing pending transactions: \(error)")
|
|
823
|
-
}
|
|
824
|
-
}
|
|
825
|
-
|
|
826
|
-
private func notifyMinedTransaction(_ transaction: PendingTransactionEntity) {
|
|
827
|
-
DispatchQueue.main.async { [weak self] in
|
|
828
|
-
guard let self = self else { return }
|
|
829
|
-
|
|
830
|
-
NotificationCenter.default.post(
|
|
831
|
-
name: Notification.Name.synchronizerMinedTransaction,
|
|
832
|
-
object: self,
|
|
833
|
-
userInfo: [NotificationKeys.minedTransaction: transaction]
|
|
834
|
-
)
|
|
578
|
+
newState = await snapshotState(status: newStatus)
|
|
835
579
|
}
|
|
580
|
+
|
|
581
|
+
latestState = newState
|
|
582
|
+
updateStateStream(with: latestState)
|
|
836
583
|
}
|
|
837
584
|
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
switch compactBlockProcessorError {
|
|
842
|
-
case .dataDbInitFailed(let path):
|
|
843
|
-
return SynchronizerError.initFailed(message: "DataDb init failed at path: \(path)")
|
|
844
|
-
case .connectionError(let message):
|
|
845
|
-
return SynchronizerError.connectionFailed(message: message)
|
|
846
|
-
case .invalidConfiguration:
|
|
847
|
-
return SynchronizerError.generalError(message: "Invalid Configuration")
|
|
848
|
-
case .missingDbPath(let path):
|
|
849
|
-
return SynchronizerError.initFailed(message: "missing Db path: \(path)")
|
|
850
|
-
case .generalError(let message):
|
|
851
|
-
return SynchronizerError.generalError(message: message)
|
|
852
|
-
case .maxAttemptsReached(attempts: let attempts):
|
|
853
|
-
return SynchronizerError.maxRetryAttemptsReached(attempts: attempts)
|
|
854
|
-
case let .grpcError(statusCode, message):
|
|
855
|
-
return SynchronizerError.connectionError(status: statusCode, message: message)
|
|
856
|
-
case .connectionTimeout:
|
|
857
|
-
return SynchronizerError.networkTimeout
|
|
858
|
-
case .unspecifiedError(let underlyingError):
|
|
859
|
-
return SynchronizerError.uncategorized(underlyingError: underlyingError)
|
|
860
|
-
case .criticalError:
|
|
861
|
-
return SynchronizerError.criticalError
|
|
862
|
-
case .invalidAccount:
|
|
863
|
-
return SynchronizerError.invalidAccount
|
|
864
|
-
case .wrongConsensusBranchId:
|
|
865
|
-
return SynchronizerError.lightwalletdValidationFailed(underlyingError: compactBlockProcessorError)
|
|
866
|
-
case .networkMismatch:
|
|
867
|
-
return SynchronizerError.lightwalletdValidationFailed(underlyingError: compactBlockProcessorError)
|
|
868
|
-
case .saplingActivationMismatch:
|
|
869
|
-
return SynchronizerError.lightwalletdValidationFailed(underlyingError: compactBlockProcessorError)
|
|
870
|
-
}
|
|
585
|
+
private func updateStateStream(with newState: SynchronizerState) {
|
|
586
|
+
streamsUpdateQueue.async { [weak self] in
|
|
587
|
+
self?.stateSubject.send(newState)
|
|
871
588
|
}
|
|
872
|
-
|
|
873
|
-
return SynchronizerError.uncategorized(underlyingError: error)
|
|
874
589
|
}
|
|
875
|
-
|
|
876
|
-
private func
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
NotificationCenter.default.post(
|
|
880
|
-
name: Notification.Name.synchronizerFailed,
|
|
881
|
-
object: self,
|
|
882
|
-
userInfo: [NotificationKeys.error: self.mapError(error)]
|
|
883
|
-
)
|
|
590
|
+
|
|
591
|
+
private func notifyMinedTransaction(_ transaction: ZcashTransaction.Overview) {
|
|
592
|
+
streamsUpdateQueue.async { [weak self] in
|
|
593
|
+
self?.eventSubject.send(.minedTransaction(transaction))
|
|
884
594
|
}
|
|
885
595
|
}
|
|
886
596
|
}
|
|
887
597
|
|
|
888
598
|
extension SDKSynchronizer {
|
|
889
|
-
public var
|
|
890
|
-
|
|
599
|
+
public var transactions: [ZcashTransaction.Overview] {
|
|
600
|
+
get async {
|
|
601
|
+
(try? await self.allTransactions()) ?? []
|
|
602
|
+
}
|
|
891
603
|
}
|
|
892
|
-
|
|
893
|
-
public var
|
|
894
|
-
|
|
604
|
+
|
|
605
|
+
public var sentTransactions: [ZcashTransaction.Overview] {
|
|
606
|
+
get async {
|
|
607
|
+
(try? await allSentTransactions()) ?? []
|
|
608
|
+
}
|
|
895
609
|
}
|
|
896
|
-
|
|
897
|
-
public var
|
|
898
|
-
|
|
610
|
+
|
|
611
|
+
public var receivedTransactions: [ZcashTransaction.Overview] {
|
|
612
|
+
get async {
|
|
613
|
+
(try? await allReceivedTransactions()) ?? []
|
|
614
|
+
}
|
|
899
615
|
}
|
|
900
|
-
|
|
901
|
-
public var
|
|
902
|
-
|
|
616
|
+
|
|
617
|
+
public var pendingTransactions: [ZcashTransaction.Overview] {
|
|
618
|
+
get async {
|
|
619
|
+
(try? await allPendingTransactions()) ?? []
|
|
620
|
+
}
|
|
903
621
|
}
|
|
904
622
|
}
|
|
905
623
|
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
case .
|
|
911
|
-
|
|
912
|
-
case .
|
|
913
|
-
|
|
914
|
-
case .
|
|
915
|
-
|
|
916
|
-
case .
|
|
917
|
-
|
|
918
|
-
case .transientFailure:
|
|
919
|
-
self = .reconnecting
|
|
624
|
+
extension InternalSyncStatus {
|
|
625
|
+
func isDifferent(from otherStatus: InternalSyncStatus) -> Bool {
|
|
626
|
+
switch (self, otherStatus) {
|
|
627
|
+
case (.unprepared, .unprepared): return false
|
|
628
|
+
case (.syncing, .syncing): return false
|
|
629
|
+
case (.enhancing, .enhancing): return false
|
|
630
|
+
case (.fetching, .fetching): return false
|
|
631
|
+
case (.synced, .synced): return false
|
|
632
|
+
case (.stopped, .stopped): return false
|
|
633
|
+
case (.disconnected, .disconnected): return false
|
|
634
|
+
case (.error, .error): return false
|
|
635
|
+
default: return true
|
|
920
636
|
}
|
|
921
637
|
}
|
|
922
638
|
}
|
|
923
639
|
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
var
|
|
928
|
-
|
|
640
|
+
struct SessionTicker {
|
|
641
|
+
/// Helper function to determine whether we are in front of a SyncSession change for a given syncStatus
|
|
642
|
+
/// transition we consider that every sync attempt is a new sync session and should have it's unique UUID reported.
|
|
643
|
+
var isNewSyncSession: (InternalSyncStatus, InternalSyncStatus) -> Bool
|
|
644
|
+
}
|
|
645
|
+
|
|
646
|
+
extension SessionTicker {
|
|
647
|
+
static let live = SessionTicker { oldStatus, newStatus in
|
|
648
|
+
// if the state hasn't changed to a different syncStatus member
|
|
649
|
+
guard oldStatus.isDifferent(from: newStatus) else { return false }
|
|
650
|
+
|
|
651
|
+
switch (oldStatus, newStatus) {
|
|
652
|
+
case (.unprepared, .syncing):
|
|
653
|
+
return true
|
|
654
|
+
case (.error, .syncing),
|
|
655
|
+
(.disconnected, .syncing),
|
|
656
|
+
(.stopped, .syncing),
|
|
657
|
+
(.synced, .syncing):
|
|
658
|
+
return true
|
|
659
|
+
default:
|
|
660
|
+
return false
|
|
661
|
+
}
|
|
662
|
+
}
|
|
929
663
|
}
|