summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Makefile.am1
-rw-r--r--src/auditor/Makefile.am7
-rw-r--r--src/auditor/auditor-basedb.age2
-rw-r--r--src/auditor/auditor-basedb.conf183
-rw-r--r--src/auditor/auditor-basedb.mpub2
-rw-r--r--src/auditor/auditor-basedb.sql12350
-rw-r--r--src/auditor/batch.conf183
-rwxr-xr-xsrc/auditor/batch.sh235
-rw-r--r--src/auditor/generate-auditor-basedb.conf32
-rwxr-xr-xsrc/auditor/generate-auditor-basedb.sh25
-rwxr-xr-xsrc/auditor/generate-revoke-basedb.sh25
-rw-r--r--src/auditor/report-lib.c225
-rw-r--r--src/auditor/report-lib.h17
-rw-r--r--src/auditor/revoke-basedb.age2
-rw-r--r--src/auditor/revoke-basedb.conf (renamed from src/auditor/test-auditor.conf)3
-rw-r--r--src/auditor/revoke-basedb.mpub2
-rw-r--r--src/auditor/revoke-basedb.sql12373
-rw-r--r--src/auditor/taler-auditor-httpd_deposit-confirmation.c91
-rw-r--r--src/auditor/taler-auditor-sync.c25
-rw-r--r--src/auditor/taler-auditor.in15
-rw-r--r--src/auditor/taler-helper-auditor-aggregation.c149
-rw-r--r--src/auditor/taler-helper-auditor-coins.c767
-rw-r--r--src/auditor/taler-helper-auditor-reserves.c848
-rw-r--r--src/auditor/taler-helper-auditor-wire.c49
-rwxr-xr-xsrc/auditor/test-auditor.sh149
-rwxr-xr-xsrc/auditor/test-revocation.sh7
-rwxr-xr-xsrc/auditor/test-sync.sh3
-rw-r--r--src/auditordb/auditor-0001.sql11
-rw-r--r--src/auditordb/auditordb_plugin.c11
-rw-r--r--src/auditordb/plugin_auditordb_postgres.c142
-rw-r--r--src/auditordb/test_auditordb.c61
-rw-r--r--src/bank-lib/bank_api_common.c4
-rw-r--r--src/bank-lib/bank_api_transfer.c39
-rw-r--r--src/bank-lib/fakebank.c215
-rw-r--r--src/bank-lib/taler-fakebank-run.c21
-rwxr-xr-xsrc/bank-lib/test_bank.sh7
-rw-r--r--src/benchmark/Makefile.am5
-rw-r--r--src/benchmark/bank-benchmark-cs.conf128
-rw-r--r--src/benchmark/bank-benchmark-rsa.conf (renamed from src/benchmark/bank-benchmark.conf)5
-rw-r--r--src/benchmark/benchmark-cs.conf126
-rw-r--r--src/benchmark/benchmark-rsa.conf (renamed from src/benchmark/benchmark.conf)5
-rw-r--r--src/benchmark/taler-aggregator-benchmark.c140
-rw-r--r--src/benchmark/taler-bank-benchmark.c125
-rw-r--r--src/benchmark/taler-exchange-benchmark.c1
-rw-r--r--src/exchange-tools/Makefile.am3
-rw-r--r--src/exchange-tools/taler-auditor-offline.c69
-rw-r--r--src/exchange-tools/taler-crypto-worker.c231
-rw-r--r--src/exchange-tools/taler-exchange-dbinit.c108
-rw-r--r--src/exchange-tools/taler-exchange-offline.c1061
-rw-r--r--src/exchange/.gitignore2
-rw-r--r--src/exchange/Makefile.am47
-rw-r--r--src/exchange/exchange.conf20
-rw-r--r--src/exchange/taler-exchange-aggregator.c529
-rw-r--r--src/exchange/taler-exchange-closer.c8
-rw-r--r--src/exchange/taler-exchange-expire.c504
-rw-r--r--src/exchange/taler-exchange-httpd.c406
-rw-r--r--src/exchange/taler-exchange-httpd.h22
-rw-r--r--src/exchange/taler-exchange-httpd_auditors.c12
-rw-r--r--src/exchange/taler-exchange-httpd_auditors.h2
-rw-r--r--src/exchange/taler-exchange-httpd_batch-withdraw.c691
-rw-r--r--src/exchange/taler-exchange-httpd_batch-withdraw.h48
-rw-r--r--src/exchange/taler-exchange-httpd_contract.c99
-rw-r--r--src/exchange/taler-exchange-httpd_contract.h44
-rw-r--r--src/exchange/taler-exchange-httpd_csr.c345
-rw-r--r--src/exchange/taler-exchange-httpd_csr.h56
-rw-r--r--src/exchange/taler-exchange-httpd_db.c34
-rw-r--r--src/exchange/taler-exchange-httpd_db.h15
-rw-r--r--src/exchange/taler-exchange-httpd_deposit.c166
-rw-r--r--src/exchange/taler-exchange-httpd_deposits_get.c220
-rw-r--r--src/exchange/taler-exchange-httpd_extensions.c179
-rw-r--r--src/exchange/taler-exchange-httpd_keys.c1206
-rw-r--r--src/exchange/taler-exchange-httpd_keys.h173
-rw-r--r--src/exchange/taler-exchange-httpd_kyc-check.c96
-rw-r--r--src/exchange/taler-exchange-httpd_kyc-check.h2
-rw-r--r--src/exchange/taler-exchange-httpd_kyc-proof.c31
-rw-r--r--src/exchange/taler-exchange-httpd_kyc-wallet.c13
-rw-r--r--src/exchange/taler-exchange-httpd_link.c16
-rw-r--r--src/exchange/taler-exchange-httpd_management.h15
-rw-r--r--src/exchange/taler-exchange-httpd_management_auditors.c2
-rw-r--r--src/exchange/taler-exchange-httpd_management_auditors_AP_disable.c2
-rw-r--r--src/exchange/taler-exchange-httpd_management_denominations_HDP_revoke.c3
-rw-r--r--src/exchange/taler-exchange-httpd_management_extensions.c277
-rw-r--r--src/exchange/taler-exchange-httpd_management_global_fees.c270
-rw-r--r--src/exchange/taler-exchange-httpd_management_post_keys.c13
-rw-r--r--src/exchange/taler-exchange-httpd_management_signkey_EP_revoke.c1
-rw-r--r--src/exchange/taler-exchange-httpd_management_wire_disable.c2
-rw-r--r--src/exchange/taler-exchange-httpd_management_wire_enable.c21
-rw-r--r--src/exchange/taler-exchange-httpd_management_wire_fees.c44
-rw-r--r--src/exchange/taler-exchange-httpd_melt.c96
-rw-r--r--src/exchange/taler-exchange-httpd_melt.h6
-rw-r--r--src/exchange/taler-exchange-httpd_metrics.c99
-rw-r--r--src/exchange/taler-exchange-httpd_metrics.h80
-rw-r--r--src/exchange/taler-exchange-httpd_mhd.h2
-rw-r--r--src/exchange/taler-exchange-httpd_purses_create.c887
-rw-r--r--src/exchange/taler-exchange-httpd_purses_create.h47
-rw-r--r--src/exchange/taler-exchange-httpd_purses_deposit.c677
-rw-r--r--src/exchange/taler-exchange-httpd_purses_deposit.h47
-rw-r--r--src/exchange/taler-exchange-httpd_purses_get.c441
-rw-r--r--src/exchange/taler-exchange-httpd_purses_get.h51
-rw-r--r--src/exchange/taler-exchange-httpd_purses_merge.c598
-rw-r--r--src/exchange/taler-exchange-httpd_purses_merge.h46
-rw-r--r--src/exchange/taler-exchange-httpd_recoup-refresh.c61
-rw-r--r--src/exchange/taler-exchange-httpd_recoup-refresh.h2
-rw-r--r--src/exchange/taler-exchange-httpd_recoup.c80
-rw-r--r--src/exchange/taler-exchange-httpd_refreshes_reveal.c520
-rw-r--r--src/exchange/taler-exchange-httpd_refund.c43
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_get.c110
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_history.c297
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_history.h43
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_purse.c718
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_purse.h46
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_status.c239
-rw-r--r--src/exchange/taler-exchange-httpd_reserves_status.h43
-rw-r--r--src/exchange/taler-exchange-httpd_responses.c630
-rw-r--r--src/exchange/taler-exchange-httpd_responses.h42
-rw-r--r--src/exchange/taler-exchange-httpd_transfers_get.c67
-rw-r--r--src/exchange/taler-exchange-httpd_wire.c368
-rw-r--r--src/exchange/taler-exchange-httpd_wire.h14
-rw-r--r--src/exchange/taler-exchange-httpd_withdraw.c227
-rw-r--r--src/exchange/taler-exchange-httpd_withdraw.h10
-rw-r--r--src/exchange/taler-exchange-router.c450
-rw-r--r--src/exchange/taler-exchange-wirewatch.c541
-rw-r--r--src/exchange/test_taler_exchange_httpd.conf42
-rw-r--r--src/exchange/test_taler_exchange_unix.conf42
-rw-r--r--src/exchangedb/.gitignore5
-rw-r--r--src/exchangedb/Makefile.am54
-rw-r--r--src/exchangedb/common-0001.sql2747
-rw-r--r--src/exchangedb/drop-common.sql97
-rw-r--r--src/exchangedb/drop0001-exchange-part.sql (renamed from src/exchangedb/drop0001.sql)63
-rw-r--r--src/exchangedb/drop0001-shard-part.sql27
-rw-r--r--src/exchangedb/exchange-0001-part.sql3625
-rw-r--r--src/exchangedb/exchange-0001.sql1876
-rw-r--r--src/exchangedb/exchangedb.conf4
-rw-r--r--src/exchangedb/exchangedb_transactions.c24
-rw-r--r--src/exchangedb/irbt_callbacks.c495
-rw-r--r--src/exchangedb/lrbt_callbacks.c909
-rw-r--r--src/exchangedb/plugin_exchangedb_common.c25
-rw-r--r--src/exchangedb/plugin_exchangedb_postgres.c6430
-rw-r--r--src/exchangedb/shard-0001-part.sql273
-rw-r--r--src/exchangedb/test-exchange-db-postgres.conf3
-rw-r--r--src/exchangedb/test_exchangedb.c661
-rw-r--r--src/extensions/Makefile.am33
-rw-r--r--src/extensions/extension_age_restriction.c411
-rw-r--r--src/extensions/extensions.c336
-rw-r--r--src/include/.gitignore1
-rw-r--r--src/include/taler_amount_lib.h12
-rw-r--r--src/include/taler_auditor_service.h8
-rw-r--r--src/include/taler_auditordb_plugin.h129
-rw-r--r--src/include/taler_crypto_lib.h3229
-rw-r--r--src/include/taler_exchange_service.h2104
-rw-r--r--src/include/taler_exchangedb_plugin.h2017
-rw-r--r--src/include/taler_extensions.h216
-rw-r--r--src/include/taler_json_lib.h236
-rw-r--r--src/include/taler_mhd_lib.h14
-rw-r--r--src/include/taler_pq_lib.h59
-rw-r--r--src/include/taler_signatures.h1731
-rw-r--r--src/include/taler_testing_lib.h396
-rw-r--r--src/include/taler_util.h67
-rw-r--r--src/json/json.c45
-rw-r--r--src/json/json_helper.c607
-rw-r--r--src/json/json_pack.c178
-rw-r--r--src/json/json_wire.c4
-rw-r--r--src/json/test_json.c65
-rw-r--r--src/lib/Makefile.am18
-rw-r--r--src/lib/auditor_api_deposit_confirmation.c40
-rw-r--r--src/lib/auditor_api_exchanges.c17
-rw-r--r--src/lib/auditor_api_handle.c254
-rw-r--r--src/lib/exchange_api_auditor_add_denomination.c15
-rw-r--r--src/lib/exchange_api_batch_withdraw.c437
-rw-r--r--src/lib/exchange_api_batch_withdraw2.c561
-rw-r--r--src/lib/exchange_api_common.c2389
-rw-r--r--src/lib/exchange_api_common.h197
-rw-r--r--src/lib/exchange_api_contracts_get.c272
-rw-r--r--src/lib/exchange_api_csr_melt.c321
-rw-r--r--src/lib/exchange_api_csr_withdraw.c284
-rw-r--r--src/lib/exchange_api_deposit.c185
-rw-r--r--src/lib/exchange_api_deposits_get.c118
-rw-r--r--src/lib/exchange_api_handle.c492
-rw-r--r--src/lib/exchange_api_handle.h5
-rw-r--r--src/lib/exchange_api_kyc_check.c24
-rw-r--r--src/lib/exchange_api_kyc_proof.c22
-rw-r--r--src/lib/exchange_api_kyc_wallet.c14
-rw-r--r--src/lib/exchange_api_link.c192
-rw-r--r--src/lib/exchange_api_management_auditor_disable.c13
-rw-r--r--src/lib/exchange_api_management_auditor_enable.c13
-rw-r--r--src/lib/exchange_api_management_get_keys.c24
-rw-r--r--src/lib/exchange_api_management_post_extensions.c101
-rw-r--r--src/lib/exchange_api_management_post_keys.c13
-rw-r--r--src/lib/exchange_api_management_revoke_denomination_key.c14
-rw-r--r--src/lib/exchange_api_management_revoke_signing_key.c13
-rw-r--r--src/lib/exchange_api_management_set_global_fee.c225
-rw-r--r--src/lib/exchange_api_management_set_wire_fee.c26
-rw-r--r--src/lib/exchange_api_management_wire_disable.c13
-rw-r--r--src/lib/exchange_api_management_wire_enable.c25
-rw-r--r--src/lib/exchange_api_melt.c590
-rw-r--r--src/lib/exchange_api_purse_create_with_deposit.c719
-rw-r--r--src/lib/exchange_api_purse_create_with_merge.c552
-rw-r--r--src/lib/exchange_api_purse_deposit.c596
-rw-r--r--src/lib/exchange_api_purse_merge.c435
-rw-r--r--src/lib/exchange_api_purses_get.c290
-rw-r--r--src/lib/exchange_api_recoup.c146
-rw-r--r--src/lib/exchange_api_recoup_refresh.c187
-rw-r--r--src/lib/exchange_api_refresh_common.c538
-rw-r--r--src/lib/exchange_api_refresh_common.h107
-rw-r--r--src/lib/exchange_api_refreshes_reveal.c262
-rw-r--r--src/lib/exchange_api_refund.c179
-rw-r--r--src/lib/exchange_api_reserves_get.c107
-rw-r--r--src/lib/exchange_api_reserves_history.c379
-rw-r--r--src/lib/exchange_api_reserves_status.c343
-rw-r--r--src/lib/exchange_api_transfers_get.c58
-rw-r--r--src/lib/exchange_api_wire.c20
-rw-r--r--src/lib/exchange_api_withdraw.c202
-rw-r--r--src/lib/exchange_api_withdraw2.c67
-rw-r--r--src/mhd/mhd_legal.c42
-rw-r--r--src/mhd/mhd_parsing.c94
-rw-r--r--src/mhd/mhd_responses.c45
-rw-r--r--src/pq/pq_query_helper.c213
-rw-r--r--src/pq/pq_result_helper.c288
-rw-r--r--src/testing/.gitignore19
-rw-r--r--src/testing/Makefile.am283
-rw-r--r--src/testing/test-taler-exchange-aggregator-postgres.conf3
-rw-r--r--src/testing/test-taler-exchange-wirewatch-postgres.conf3
-rw-r--r--src/testing/test_auditor_api-cs.conf (renamed from src/testing/test_exchange_api.conf)45
-rw-r--r--src/testing/test_auditor_api-rsa.conf (renamed from src/testing/test_auditor_api.conf)10
-rw-r--r--src/testing/test_auditor_api.c80
-rw-r--r--src/testing/test_auditor_api_expire_reserve_now-cs.conf (renamed from src/testing/test_auditor_api_expire_reserve_now.conf)2
-rw-r--r--src/testing/test_auditor_api_expire_reserve_now-rsa.conf (renamed from src/testing/test_exchange_api_expire_reserve_now.conf)2
-rw-r--r--src/testing/test_bank_api_fakebank.conf2
-rw-r--r--src/testing/test_bank_api_fakebank_twisted.conf4
-rw-r--r--src/testing/test_bank_api_pybank.conf21
-rw-r--r--src/testing/test_bank_api_pybank_twisted.conf43
-rw-r--r--src/testing/test_exchange_api-cs.conf209
-rw-r--r--src/testing/test_exchange_api-rsa.conf220
-rw-r--r--src/testing/test_exchange_api.c433
-rw-r--r--src/testing/test_exchange_api_expire_reserve_now-cs.conf4
-rw-r--r--src/testing/test_exchange_api_expire_reserve_now-rsa.conf4
-rw-r--r--src/testing/test_exchange_api_keys_cherry_picking-cs.conf98
-rw-r--r--src/testing/test_exchange_api_keys_cherry_picking-rsa.conf (renamed from src/testing/test_exchange_api_keys_cherry_picking.conf)5
-rw-r--r--src/testing/test_exchange_api_keys_cherry_picking.c27
-rw-r--r--src/testing/test_exchange_api_overlapping_keys_bug.c27
-rw-r--r--src/testing/test_exchange_api_revocation.c38
-rw-r--r--src/testing/test_exchange_api_twisted-cs.conf (renamed from src/testing/test_exchange_api_twisted.conf)14
-rw-r--r--src/testing/test_exchange_api_twisted-rsa.conf156
-rw-r--r--src/testing/test_exchange_api_twisted.c40
-rw-r--r--src/testing/test_exchange_management_api.c45
-rw-r--r--src/testing/test_exchange_p2p.c472
-rw-r--r--src/testing/test_kyc_api.c13
-rw-r--r--src/testing/test_kyc_api.conf67
-rw-r--r--src/testing/test_taler_exchange_aggregator.c7
-rw-r--r--src/testing/test_taler_exchange_wirewatch.c3
-rw-r--r--src/testing/testing_api_cmd_auditor_add_denom_sig.c7
-rw-r--r--src/testing/testing_api_cmd_auditor_deposit_confirmation.c9
-rw-r--r--src/testing/testing_api_cmd_auditor_exec_auditor.c1
-rw-r--r--src/testing/testing_api_cmd_bank_admin_add_incoming.c12
-rw-r--r--src/testing/testing_api_cmd_bank_check.c27
-rw-r--r--src/testing/testing_api_cmd_bank_history_credit.c20
-rw-r--r--src/testing/testing_api_cmd_bank_history_debit.c18
-rw-r--r--src/testing/testing_api_cmd_batch_withdraw.c537
-rw-r--r--src/testing/testing_api_cmd_change_auth.c19
-rw-r--r--src/testing/testing_api_cmd_common.c175
-rw-r--r--src/testing/testing_api_cmd_contract_get.c316
-rw-r--r--src/testing/testing_api_cmd_deposit.c59
-rw-r--r--src/testing/testing_api_cmd_deposits_get.c4
-rw-r--r--src/testing/testing_api_cmd_exec_closer.c5
-rw-r--r--src/testing/testing_api_cmd_exec_expire.c162
-rw-r--r--src/testing/testing_api_cmd_exec_router.c161
-rw-r--r--src/testing/testing_api_cmd_insert_deposit.c95
-rw-r--r--src/testing/testing_api_cmd_kyc_check_get.c5
-rw-r--r--src/testing/testing_api_cmd_kyc_proof.c37
-rw-r--r--src/testing/testing_api_cmd_oauth.c7
-rw-r--r--src/testing/testing_api_cmd_offline_sign_extensions.c164
-rw-r--r--src/testing/testing_api_cmd_offline_sign_global_fees.c252
-rw-r--r--src/testing/testing_api_cmd_offline_sign_wire_fees.c (renamed from src/testing/testing_api_cmd_offline_sign_fees.c)12
-rw-r--r--src/testing/testing_api_cmd_purse_create_deposit.c432
-rw-r--r--src/testing/testing_api_cmd_purse_deposit.c481
-rw-r--r--src/testing/testing_api_cmd_purse_get.c371
-rw-r--r--src/testing/testing_api_cmd_purse_merge.c400
-rw-r--r--src/testing/testing_api_cmd_recoup.c91
-rw-r--r--src/testing/testing_api_cmd_recoup_refresh.c163
-rw-r--r--src/testing/testing_api_cmd_refresh.c316
-rw-r--r--src/testing/testing_api_cmd_refund.c3
-rw-r--r--src/testing/testing_api_cmd_reserve_get.c388
-rw-r--r--src/testing/testing_api_cmd_reserve_history.c426
-rw-r--r--src/testing/testing_api_cmd_reserve_purse.c326
-rw-r--r--src/testing/testing_api_cmd_reserve_status.c (renamed from src/testing/testing_api_cmd_status.c)229
-rw-r--r--src/testing/testing_api_cmd_serialize_keys.c18
-rw-r--r--src/testing/testing_api_cmd_set_wire_fee.c25
-rw-r--r--src/testing/testing_api_cmd_transfer_get.c2
-rw-r--r--src/testing/testing_api_cmd_wire.c2
-rw-r--r--src/testing/testing_api_cmd_withdraw.c244
-rw-r--r--src/testing/testing_api_helpers_bank.c10
-rw-r--r--src/testing/testing_api_helpers_exchange.c63
-rw-r--r--src/testing/testing_api_loop.c123
-rw-r--r--src/util/.gitignore3
-rw-r--r--src/util/Makefile.am43
-rw-r--r--src/util/age_restriction.c438
-rw-r--r--src/util/amount.c14
-rw-r--r--src/util/auditor_signatures.c119
-rw-r--r--src/util/config.c100
-rw-r--r--src/util/crypto.c224
-rw-r--r--src/util/crypto_contract.c540
-rw-r--r--src/util/crypto_helper_cs.c895
-rw-r--r--src/util/crypto_helper_rsa.c76
-rw-r--r--src/util/crypto_wire.c86
-rw-r--r--src/util/denom.c397
-rw-r--r--src/util/exchange_signatures.c1529
-rw-r--r--src/util/extension_age_restriction.c182
-rw-r--r--src/util/extensions.c49
-rw-r--r--src/util/merchant_signatures.c278
-rw-r--r--src/util/offline_signatures.c708
-rw-r--r--src/util/payto.c91
-rw-r--r--src/util/secmod_signatures.c125
-rw-r--r--src/util/taler-exchange-secmod-cs.c1625
-rw-r--r--src/util/taler-exchange-secmod-cs.conf23
-rw-r--r--src/util/taler-exchange-secmod-cs.h270
-rw-r--r--src/util/taler-exchange-secmod-eddsa.c2
-rw-r--r--src/util/taler-exchange-secmod-rsa.c640
-rw-r--r--src/util/taler-exchange-secmod-rsa.h29
-rw-r--r--src/util/test_age_restriction.c272
-rw-r--r--src/util/test_crypto.c321
-rw-r--r--src/util/test_helper_cs.c883
-rw-r--r--src/util/test_helper_cs.conf11
-rw-r--r--src/util/test_helper_rsa.c126
-rw-r--r--src/util/test_helper_rsa.conf1
-rw-r--r--src/util/tv_age_restriction.c275
-rw-r--r--src/util/tv_age_restriction.json9764
-rw-r--r--src/util/url.c52
-rw-r--r--src/util/util.c171
-rw-r--r--src/util/wallet_signatures.c1064
329 files changed, 97358 insertions, 18332 deletions
diff --git a/src/Makefile.am b/src/Makefile.am
index 64d6020f..5d46850c 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -18,6 +18,7 @@ SUBDIRS = \
include \
util \
json \
+ extensions \
curl \
$(PQ_DIR) \
$(SQ_DIR) \
diff --git a/src/auditor/Makefile.am b/src/auditor/Makefile.am
index 49f4030e..6d49da6d 100644
--- a/src/auditor/Makefile.am
+++ b/src/auditor/Makefile.am
@@ -193,14 +193,13 @@ check_SCRIPTS = \
test-sync.sh
.NOTPARALLEL:
-# Disabled for now: need working wallet first!
-# TESTS = $(check_SCRIPTS)
+# revocation test disabled for now: need working wallet first!
+TESTS = $(check_SCRIPTS)
EXTRA_DIST = \
taler-auditor.in \
taler-helper-auditor-render.py \
auditor.conf \
- test-auditor.conf \
test-sync-in.conf \
test-sync-out.conf \
generate-auditor-basedb.sh \
@@ -209,8 +208,10 @@ EXTRA_DIST = \
generate-auditor-basedb-template.conf \
$(check_SCRIPTS) \
auditor-basedb.age \
+ auditor-basedb.conf \
auditor-basedb.sql \
auditor-basedb.mpub \
revoke-basedb.age \
+ revoke-basedb.conf \
revoke-basedb.sql \
revoke-basedb.mpub
diff --git a/src/auditor/auditor-basedb.age b/src/auditor/auditor-basedb.age
index 8a55c288..808d192f 100644
--- a/src/auditor/auditor-basedb.age
+++ b/src/auditor/auditor-basedb.age
@@ -1 +1 @@
-1638356946
+1655640402
diff --git a/src/auditor/auditor-basedb.conf b/src/auditor/auditor-basedb.conf
new file mode 100644
index 00000000..5f864849
--- /dev/null
+++ b/src/auditor/auditor-basedb.conf
@@ -0,0 +1,183 @@
+[benchmark]
+MERCHANT_DETAILS = merchant_details.json
+BANK_DETAILS = bank_details.json
+
+[coin_kudos_10]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.01
+fee_refresh = TESTKUDOS:0.03
+fee_deposit = TESTKUDOS:0.01
+fee_withdraw = TESTKUDOS:0.01
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:10
+
+[coin_kudos_8]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.04
+fee_refresh = TESTKUDOS:0.03
+fee_deposit = TESTKUDOS:0.02
+fee_withdraw = TESTKUDOS:0.05
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:8
+
+[coin_kudos_5]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.01
+fee_refresh = TESTKUDOS:0.03
+fee_deposit = TESTKUDOS:0.01
+fee_withdraw = TESTKUDOS:0.01
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:5
+
+[coin_kudos_4]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.02
+fee_refresh = TESTKUDOS:0.04
+fee_deposit = TESTKUDOS:0.03
+fee_withdraw = TESTKUDOS:0.03
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:4
+
+[coin_kudos_2]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.02
+fee_refresh = TESTKUDOS:0.04
+fee_deposit = TESTKUDOS:0.03
+fee_withdraw = TESTKUDOS:0.03
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:2
+
+[coin_kudos_1]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.01
+fee_refresh = TESTKUDOS:0.03
+fee_deposit = TESTKUDOS:0.02
+fee_withdraw = TESTKUDOS:0.02
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:1
+
+[coin_kudos_ct_10]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.01
+fee_refresh = TESTKUDOS:0.03
+fee_deposit = TESTKUDOS:0.01
+fee_withdraw = TESTKUDOS:0.01
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:0.10
+
+[coin_kudos_ct_1]
+rsa_keysize = 1024
+CIPHER = RSA
+fee_refund = TESTKUDOS:0.01
+fee_refresh = TESTKUDOS:0.01
+fee_deposit = TESTKUDOS:0.01
+fee_withdraw = TESTKUDOS:0.01
+duration_legal = 3 years
+duration_spend = 2 years
+duration_withdraw = 7 days
+value = TESTKUDOS:0.01
+
+[payments-generator]
+exchange = http://localhost:8081/
+exchange-admin = http://localhost:18080/
+exchange_admin = http://localhost:18080/
+merchant = http://localhost:9966/
+bank = http://localhost:8082/
+instance = default
+currency = TESTKUDOS
+
+[merchant-exchange-default]
+CURRENCY = TESTKUDOS
+EXCHANGE_BASE_URL = http://localhost:8081/
+MASTER_KEY = JM0NJXHM6Y6HYAPK2WDFH3HDJ2E9KZWGKM3E0FYRV2V3HCTB3DQ0
+
+[merchant-account-merchant]
+ACTIVE_default = YES
+HONOR_default = YES
+PAYTO_URI = payto://x-taler-bank/localhost/42
+
+[exchange-accountcredentials-1]
+PASSWORD = x
+USERNAME = Exchange
+WIRE_GATEWAY_AUTH_METHOD = basic
+WIRE_GATEWAY_URL = http://localhost:8082/taler-wire-gateway/Exchange/
+
+[exchange-account-1]
+enable_credit = yes
+enable_debit = yes
+PAYTO_URI = payto://x-taler-bank/localhost/Exchange
+
+[instance-default]
+NAME = Merchant Inc.
+KEYFILE = ${TALER_DATA_HOME}/merchant/default.priv
+
+[taler]
+CURRENCY_ROUND_UNIT = TESTKUDOS:0.01
+CURRENCY = TESTKUDOS
+
+[merchantdb-postgres]
+CONFIG = postgres:///auditor-basedb
+
+[merchant]
+DEFAULT_MAX_WIRE_FEE = TESTKUDOS:0.10
+KEYFILE = ${TALER_DATA_HOME}/merchant/merchant.priv
+DEFAULT_MAX_DEPOSIT_FEE = TESTKUDOS:0.1
+WIREFORMAT = default
+WIRE_TRANSFER_DELAY = 1 minute
+FORCE_AUDIT = YES
+UNIXPATH = ${TALER_RUNTIME_DIR}/merchant.http
+
+[exchangedb-postgres]
+CONFIG = postgres:///auditor-basedb
+
+[exchange]
+LOOKAHEAD_SIGN = 32 weeks 1 day
+SIGNKEY_DURATION = 4 weeks
+MASTER_PUBLIC_KEY = JM0NJXHM6Y6HYAPK2WDFH3HDJ2E9KZWGKM3E0FYRV2V3HCTB3DQ0
+SIGNKEY_LEGAL_DURATION = 4 weeks
+UNIXPATH = ${TALER_RUNTIME_DIR}/exchange.http
+
+[bank]
+SERVE = http
+ALLOW_REGISTRATIONS = YES
+SUGGESTED_EXCHANGE_PAYTO = payto://x-taler-bank/localhost/2
+SUGGESTED_EXCHANGE = http://localhost:8081/
+HTTP_PORT = 8082
+MAX_DEBT_BANK = TESTKUDOS:100000.0
+MAX_DEBT = TESTKUDOS:50.0
+DATABASE = postgres:///auditor-basedb
+
+[auditordb-postgres]
+CONFIG = postgres:///auditor-basedb
+
+[auditor]
+PUBLIC_KEY = 73NJKBP4MHJF8274K88F4WFWKNYMK8T6MTSE6HHYS6WC01H9YH7G
+TINY_AMOUNT = TESTKUDOS:0.01
+BASE_URL = http://localhost:8083/
+
+[PATHS]
+TALER_CACHE_HOME = $TALER_HOME/.cache/taler/
+TALER_CONFIG_HOME = $TALER_HOME/.config/taler/
+TALER_DATA_HOME = $TALER_HOME/.local/share/taler/
+TALER_HOME = ${PWD}/generate_auditordb_home/
diff --git a/src/auditor/auditor-basedb.mpub b/src/auditor/auditor-basedb.mpub
index 13f7e591..ede1a731 100644
--- a/src/auditor/auditor-basedb.mpub
+++ b/src/auditor/auditor-basedb.mpub
@@ -1 +1 @@
-R8JBA9089F3YRRSQDPWB92CZ5V1V0J1BPVW8J1B0P8VCVH71CYY0
+JM0NJXHM6Y6HYAPK2WDFH3HDJ2E9KZWGKM3E0FYRV2V3HCTB3DQ0
diff --git a/src/auditor/auditor-basedb.sql b/src/auditor/auditor-basedb.sql
index fbbba67b..69950d5b 100644
--- a/src/auditor/auditor-basedb.sql
+++ b/src/auditor/auditor-basedb.sql
@@ -2,8 +2,8 @@
-- PostgreSQL database dump
--
--- Dumped from database version 13.4
--- Dumped by pg_dump version 13.4
+-- Dumped from database version 13.7 (Debian 13.7-0+deb11u1)
+-- Dumped by pg_dump version 13.7 (Debian 13.7-0+deb11u1)
SET statement_timeout = 0;
SET lock_timeout = 0;
@@ -256,6 +256,5205 @@ $$;
COMMENT ON FUNCTION _v.unregister_patch(in_patch_name text, OUT versioning integer) IS 'Function to unregister patches in database. Dies if the patch is not registered, or if unregistering it would break dependencies.';
+--
+-- Name: add_constraints_to_account_merges_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_account_merges_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE account_merges_' || partition_suffix || ' '
+ 'ADD CONSTRAINT account_merges_' || partition_suffix || '_account_merge_request_serial_id_key '
+ 'UNIQUE (account_merge_request_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_aggregation_tracking_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_aggregation_tracking_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE aggregation_tracking_' || partition_suffix || ' '
+ 'ADD CONSTRAINT aggregation_tracking_' || partition_suffix || '_aggregation_serial_id_key '
+ 'UNIQUE (aggregation_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_contracts_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_contracts_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE contracts_' || partition_suffix || ' '
+ 'ADD CONSTRAINT contracts_' || partition_suffix || '_contract_serial_id_key '
+ 'UNIQUE (contract_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_cs_nonce_locks_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_cs_nonce_locks_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE cs_nonce_locks_' || partition_suffix || ' '
+ 'ADD CONSTRAINT cs_nonce_locks_' || partition_suffix || '_cs_nonce_lock_serial_id_key '
+ 'UNIQUE (cs_nonce_lock_serial_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_deposits_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_deposits_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE deposits_' || partition_suffix || ' '
+ 'ADD CONSTRAINT deposits_' || partition_suffix || '_deposit_serial_id_pkey '
+ 'PRIMARY KEY (deposit_serial_id) '
+ ',ADD CONSTRAINT deposits_' || partition_suffix || '_coin_pub_merchant_pub_h_contract_terms_key '
+ 'UNIQUE (coin_pub, merchant_pub, h_contract_terms)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_known_coins_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_known_coins_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE known_coins_' || partition_suffix || ' '
+ 'ADD CONSTRAINT known_coins_' || partition_suffix || '_known_coin_id_key '
+ 'UNIQUE (known_coin_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_purse_deposits_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_purse_deposits_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE purse_deposits_' || partition_suffix || ' '
+ 'ADD CONSTRAINT purse_deposits_' || partition_suffix || '_purse_deposit_serial_id_key '
+ 'UNIQUE (purse_deposit_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_purse_merges_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_purse_merges_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE purse_merges_' || partition_suffix || ' '
+ 'ADD CONSTRAINT purse_merges_' || partition_suffix || '_purse_merge_request_serial_id_key '
+ 'UNIQUE (purse_merge_request_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_purse_refunds_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_purse_refunds_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE purse_refunds_' || partition_suffix || ' '
+ 'ADD CONSTRAINT purse_refunds_' || partition_suffix || '_purse_refunds_serial_id_key '
+ 'UNIQUE (purse_refunds_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_purse_requests_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_purse_requests_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE purse_requests_' || partition_suffix || ' '
+ 'ADD CONSTRAINT purse_requests_' || partition_suffix || '_purse_requests_serial_id_key '
+ 'UNIQUE (purse_requests_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_recoup_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_recoup_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE recoup_' || partition_suffix || ' '
+ 'ADD CONSTRAINT recoup_' || partition_suffix || '_recoup_uuid_key '
+ 'UNIQUE (recoup_uuid) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_recoup_refresh_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_recoup_refresh_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE recoup_refresh_' || partition_suffix || ' '
+ 'ADD CONSTRAINT recoup_refresh_' || partition_suffix || '_recoup_refresh_uuid_key '
+ 'UNIQUE (recoup_refresh_uuid) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_refresh_commitments_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_refresh_commitments_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE refresh_commitments_' || partition_suffix || ' '
+ 'ADD CONSTRAINT refresh_commitments_' || partition_suffix || '_melt_serial_id_key '
+ 'UNIQUE (melt_serial_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_refresh_revealed_coins_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_refresh_revealed_coins_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE refresh_revealed_coins_' || partition_suffix || ' '
+ 'ADD CONSTRAINT refresh_revealed_coins_' || partition_suffix || '_rrc_serial_key '
+ 'UNIQUE (rrc_serial) '
+ ',ADD CONSTRAINT refresh_revealed_coins_' || partition_suffix || '_coin_ev_key '
+ 'UNIQUE (coin_ev) '
+ ',ADD CONSTRAINT refresh_revealed_coins_' || partition_suffix || '_h_coin_ev_key '
+ 'UNIQUE (h_coin_ev) '
+ ',ADD PRIMARY KEY (melt_serial_id, freshcoin_index) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_refresh_transfer_keys_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_refresh_transfer_keys_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE refresh_transfer_keys_' || partition_suffix || ' '
+ 'ADD CONSTRAINT refresh_transfer_keys_' || partition_suffix || '_rtc_serial_key '
+ 'UNIQUE (rtc_serial)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_refunds_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_refunds_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE refunds_' || partition_suffix || ' '
+ 'ADD CONSTRAINT refunds_' || partition_suffix || '_refund_serial_id_key '
+ 'UNIQUE (refund_serial_id) '
+ ',ADD PRIMARY KEY (deposit_serial_id, rtransaction_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_reserves_close_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_reserves_close_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE reserves_close_' || partition_suffix || ' '
+ 'ADD CONSTRAINT reserves_close_' || partition_suffix || '_close_uuid_pkey '
+ 'PRIMARY KEY (close_uuid)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_reserves_in_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_reserves_in_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE reserves_in_' || partition_suffix || ' '
+ 'ADD CONSTRAINT reserves_in_' || partition_suffix || '_reserve_in_serial_id_key '
+ 'UNIQUE (reserve_in_serial_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_reserves_out_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_reserves_out_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE reserves_out_' || partition_suffix || ' '
+ 'ADD CONSTRAINT reserves_out_' || partition_suffix || '_reserve_out_serial_id_key '
+ 'UNIQUE (reserve_out_serial_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wad_in_entries_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wad_in_entries_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE wad_in_entries_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wad_in_entries_' || partition_suffix || '_wad_in_entry_serial_id_key '
+ 'UNIQUE (wad_in_entry_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wad_out_entries_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wad_out_entries_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE wad_out_entries_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wad_out_entries_' || partition_suffix || '_wad_out_entry_serial_id_key '
+ 'UNIQUE (wad_out_entry_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wads_in_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wads_in_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE wads_in_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wads_in_' || partition_suffix || '_wad_in_serial_id_key '
+ 'UNIQUE (wad_in_serial_id) '
+ ',ADD CONSTRAINT wads_in_' || partition_suffix || '_wad_is_origin_exchange_url_key '
+ 'UNIQUE (wad_id, origin_exchange_url) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wads_out_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wads_out_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE wads_out_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wads_out_' || partition_suffix || '_wad_out_serial_id_key '
+ 'UNIQUE (wad_out_serial_id) '
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wire_out_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wire_out_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ EXECUTE FORMAT (
+ 'ALTER TABLE wire_out_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wire_out_' || partition_suffix || '_wireout_uuid_pkey '
+ 'PRIMARY KEY (wireout_uuid)'
+ );
+END
+$$;
+
+
+--
+-- Name: add_constraints_to_wire_targets_partition(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.add_constraints_to_wire_targets_partition(partition_suffix character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ EXECUTE FORMAT (
+ 'ALTER TABLE wire_targets_' || partition_suffix || ' '
+ 'ADD CONSTRAINT wire_targets_' || partition_suffix || '_wire_target_serial_id_key '
+ 'UNIQUE (wire_target_serial_id)'
+ );
+END
+$$;
+
+
+--
+-- Name: create_foreign_hash_partition(character varying, integer, character varying, integer, character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_foreign_hash_partition(source_table_name character varying, modulus integer, shard_suffix character varying, current_shard_num integer, local_user character varying DEFAULT 'taler-exchange-httpd'::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ RAISE NOTICE 'Creating %_% on %', source_table_name, shard_suffix, shard_suffix;
+
+ EXECUTE FORMAT(
+ 'CREATE FOREIGN TABLE IF NOT EXISTS %I '
+ 'PARTITION OF %I '
+ 'FOR VALUES WITH (MODULUS %s, REMAINDER %s) '
+ 'SERVER %I'
+ ,source_table_name || '_' || shard_suffix
+ ,source_table_name
+ ,modulus
+ ,current_shard_num-1
+ ,shard_suffix
+ );
+
+ EXECUTE FORMAT(
+ 'ALTER FOREIGN TABLE %I OWNER TO %I'
+ ,source_table_name || '_' || shard_suffix
+ ,local_user
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_foreign_range_partition(character varying, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_foreign_range_partition(source_table_name character varying, partition_num integer) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ RAISE NOTICE 'TODO';
+END
+$$;
+
+
+--
+-- Name: create_foreign_servers(integer, character varying, character varying, character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_foreign_servers(amount integer, domain character varying, remote_user character varying DEFAULT 'taler'::character varying, remote_user_password character varying DEFAULT 'taler'::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ PERFORM prepare_sharding();
+
+ FOR i IN 1..amount LOOP
+ PERFORM create_shard_server(
+ i::varchar
+ ,amount
+ ,i
+ ,'shard-' || i::varchar || '.' || domain
+ ,remote_user
+ ,remote_user_password
+ ,'taler-exchange'
+ ,'5432'
+ ,'taler-exchange-httpd'
+ );
+ END LOOP;
+
+ PERFORM drop_default_partitions();
+
+END
+$$;
+
+
+--
+-- Name: create_hash_partition(character varying, integer, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_hash_partition(source_table_name character varying, modulus integer, partition_num integer) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ RAISE NOTICE 'Creating partition %_%', source_table_name, partition_num;
+
+ EXECUTE FORMAT(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ 'PARTITION OF %I '
+ 'FOR VALUES WITH (MODULUS %s, REMAINDER %s)'
+ ,source_table_name || '_' || partition_num
+ ,source_table_name
+ ,modulus
+ ,partition_num-1
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_partitioned_table(character varying, character varying, character varying, character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_partitioned_table(table_definition character varying, table_name character varying, main_table_partition_str character varying, shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ IF shard_suffix IS NOT NULL THEN
+ table_name=table_name || '_' || shard_suffix;
+ main_table_partition_str = '';
+ END IF;
+
+ EXECUTE FORMAT(
+ table_definition,
+ table_name,
+ main_table_partition_str
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_partitions(integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_partitions(num_partitions integer) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ modulus INTEGER;
+BEGIN
+
+ modulus := num_partitions;
+
+ PERFORM detach_default_partitions();
+
+ LOOP
+
+ PERFORM create_hash_partition(
+ 'wire_targets'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_wire_targets_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'reserves'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'reserves_in'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_reserves_in_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'reserves_close'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_reserves_close_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'reserves_out'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_reserves_out_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'reserves_out_by_reserve'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'known_coins'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_known_coins_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'refresh_commitments'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_refresh_commitments_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'refresh_revealed_coins'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_refresh_revealed_coins_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'refresh_transfer_keys'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_refresh_transfer_keys_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'deposits'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_deposits_partition(num_partitions::varchar);
+
+-- TODO: dynamically (!) creating/deleting deposits partitions:
+-- create new partitions 'as needed', drop old ones once the aggregator has made
+-- them empty; as 'new' deposits will always have deadlines in the future, this
+-- would basically guarantee no conflict between aggregator and exchange service!
+-- SEE also: https://www.cybertec-postgresql.com/en/automatic-partition-creation-in-postgresql/
+-- (article is slightly wrong, as this works:)
+--CREATE TABLE tab (
+-- id bigint GENERATED ALWAYS AS IDENTITY,
+-- ts timestamp NOT NULL,
+-- data text
+-- PARTITION BY LIST ((ts::date));
+-- CREATE TABLE tab_def PARTITION OF tab DEFAULT;
+-- BEGIN
+-- CREATE TABLE tab_part2 (LIKE tab);
+-- insert into tab_part2 (id,ts, data) values (5,'2022-03-21', 'foo');
+-- alter table tab attach partition tab_part2 for values in ('2022-03-21');
+-- commit;
+-- Naturally, to ensure this is actually 100% conflict-free, we'd
+-- need to create tables at the granularity of the wire/refund deadlines;
+-- that is right now configurable via AGGREGATOR_SHIFT option.
+
+-- FIXME: range partitioning
+-- PERFORM create_range_partition(
+-- 'deposits_by_ready'
+-- ,modulus
+-- ,num_partitions
+-- );
+--
+-- PERFORM create_range_partition(
+-- 'deposits_for_matching'
+-- ,modulus
+-- ,num_partitions
+-- );
+
+ PERFORM create_hash_partition(
+ 'refunds'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_refunds_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'wire_out'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_wire_out_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'aggregation_transient'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'aggregation_tracking'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_aggregation_tracking_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'recoup'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_recoup_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'recoup_by_reserve'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'recoup_refresh'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_recoup_refresh_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'prewire'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'cs_nonce_locks'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_cs_nonce_locks_partition(num_partitions::varchar);
+
+ ---------------- P2P ----------------------
+
+ PERFORM create_hash_partition(
+ 'purse_requests'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_purse_requests_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'purse_refunds'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_purse_refunds_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'purse_merges'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_purse_merges_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'account_merges'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_account_merges_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'contracts'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_contracts_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'history_requests'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'close_requests'
+ ,modulus
+ ,num_partitions
+ );
+
+ PERFORM create_hash_partition(
+ 'purse_deposits'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_purse_deposits_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'wad_out_entries'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_wad_out_entries_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'wads_in'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_wads_in_partition(num_partitions::varchar);
+
+ PERFORM create_hash_partition(
+ 'wad_in_entries'
+ ,modulus
+ ,num_partitions
+ );
+ PERFORM add_constraints_to_wad_in_entries_partition(num_partitions::varchar);
+
+ num_partitions=num_partitions-1;
+ EXIT WHEN num_partitions=0;
+
+ END LOOP;
+
+ PERFORM drop_default_partitions();
+
+END
+$$;
+
+
+--
+-- Name: create_range_partition(character varying, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_range_partition(source_table_name character varying, partition_num integer) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ RAISE NOTICE 'TODO';
+END
+$$;
+
+
+--
+-- Name: create_shard_server(character varying, integer, integer, character varying, character varying, character varying, character varying, integer, character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_shard_server(shard_suffix character varying, total_num_shards integer, current_shard_num integer, remote_host character varying, remote_user character varying, remote_user_password character varying, remote_db_name character varying DEFAULT 'taler-exchange'::character varying, remote_port integer DEFAULT 5432, local_user character varying DEFAULT 'taler-exchange-httpd'::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ RAISE NOTICE 'Creating server %', remote_host;
+
+ EXECUTE FORMAT(
+ 'CREATE SERVER IF NOT EXISTS %I '
+ 'FOREIGN DATA WRAPPER postgres_fdw '
+ 'OPTIONS (dbname %L, host %L, port %L)'
+ ,shard_suffix
+ ,remote_db_name
+ ,remote_host
+ ,remote_port
+ );
+
+ EXECUTE FORMAT(
+ 'CREATE USER MAPPING IF NOT EXISTS '
+ 'FOR %I SERVER %I '
+ 'OPTIONS (user %L, password %L)'
+ ,local_user
+ ,shard_suffix
+ ,remote_user
+ ,remote_user_password
+ );
+
+ EXECUTE FORMAT(
+ 'GRANT ALL PRIVILEGES '
+ 'ON FOREIGN SERVER %I '
+ 'TO %I;'
+ ,shard_suffix
+ ,local_user
+ );
+
+ PERFORM create_foreign_hash_partition(
+ 'wire_targets'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'reserves'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'reserves_in'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'reserves_out'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'reserves_out_by_reserve'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'reserves_close'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'known_coins'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'refresh_commitments'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'refresh_revealed_coins'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'refresh_transfer_keys'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'deposits'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+-- PERFORM create_foreign_range_partition(
+-- 'deposits_by_ready'
+-- ,total_num_shards
+-- ,shard_suffix
+-- ,current_shard_num
+-- ,local_user
+-- );
+-- PERFORM create_foreign_range_partition(
+-- 'deposits_for_matching'
+-- ,total_num_shards
+-- ,shard_suffix
+-- ,current_shard_num
+-- ,local_user
+-- );
+ PERFORM create_foreign_hash_partition(
+ 'refunds'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'wire_out'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'aggregation_transient'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'aggregation_tracking'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'recoup'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'recoup_by_reserve'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'recoup_refresh'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'prewire'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'cs_nonce_locks'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+
+ ------------------- P2P --------------------
+
+ PERFORM create_foreign_hash_partition(
+ 'purse_requests'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'purse_refunds'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'purse_merges'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'account_merges'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'contracts'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'history_requests'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'close_requests'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'purse_deposits'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'wad_out_entries'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'wads_in'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+ PERFORM create_foreign_hash_partition(
+ 'wad_in_entries'
+ ,total_num_shards
+ ,shard_suffix
+ ,current_shard_num
+ ,local_user
+ );
+
+END
+$$;
+
+
+--
+-- Name: FUNCTION create_shard_server(shard_suffix character varying, total_num_shards integer, current_shard_num integer, remote_host character varying, remote_user character varying, remote_user_password character varying, remote_db_name character varying, remote_port integer, local_user character varying); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.create_shard_server(shard_suffix character varying, total_num_shards integer, current_shard_num integer, remote_host character varying, remote_user character varying, remote_user_password character varying, remote_db_name character varying, remote_port integer, local_user character varying) IS 'Create a shard server on the master
+ node with all foreign tables and user mappings';
+
+
+--
+-- Name: create_table_account_merges(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_account_merges(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'account_merges';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(account_merge_request_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE
+ ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)' -- REFERENCES reserves (reserve_pub) ON DELETE CASCADE
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)' -- REFERENCES purse_requests (purse_pub)
+ ',PRIMARY KEY (purse_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by reserve_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_pub '
+ 'ON ' || table_name || ' '
+ '(reserve_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_aggregation_tracking(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_aggregation_tracking(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'aggregation_tracking';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(aggregation_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',deposit_serial_id INT8 PRIMARY KEY' -- REFERENCES deposits (deposit_serial_id) ON DELETE CASCADE' -- FIXME change to coint_pub + deposit_serial_id for more efficient depost -- or something else ???
+ ',wtid_raw BYTEA NOT NULL' -- CONSTRAINT wire_out_ref REFERENCES wire_out(wtid_raw) ON DELETE CASCADE DEFERRABLE'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (deposit_serial_id)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_wtid_raw_index '
+ 'ON ' || table_name || ' '
+ '(wtid_raw);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_wtid_raw_index '
+ 'IS ' || quote_literal('for lookup_transactions') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_aggregation_transient(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_aggregation_transient(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'aggregation_transient';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',wire_target_h_payto BYTEA CHECK (LENGTH(wire_target_h_payto)=32)'
+ ',exchange_account_section TEXT NOT NULL'
+ ',wtid_raw BYTEA NOT NULL CHECK (LENGTH(wtid_raw)=32)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (wire_target_h_payto)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_close_requests(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_close_requests(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'close_requests';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(close_request_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE'
+ ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)' -- REFERENCES reserves(reserve_pub) ON DELETE CASCADE
+ ',close_timestamp INT8 NOT NULL'
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',close_val INT8 NOT NULL'
+ ',close_frac INT4 NOT NULL'
+ ',PRIMARY KEY (reserve_pub,close_timestamp)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_pub)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_contracts(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_contracts(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'contracts';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(contract_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
+ ',pub_ckey BYTEA NOT NULL CHECK (LENGTH(pub_ckey)=32)'
+ ',contract_sig BYTEA NOT NULL CHECK (LENGTH(contract_sig)=64)'
+ ',e_contract BYTEA NOT NULL'
+ ',purse_expiration INT8 NOT NULL'
+ ',PRIMARY KEY (purse_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_cs_nonce_locks(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_cs_nonce_locks(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(cs_nonce_lock_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',nonce BYTEA PRIMARY KEY CHECK (LENGTH(nonce)=32)'
+ ',op_hash BYTEA NOT NULL CHECK (LENGTH(op_hash)=64)'
+ ',max_denomination_serial INT8 NOT NULL'
+ ') %s ;'
+ ,'cs_nonce_locks'
+ ,'PARTITION BY HASH (nonce)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_deposits(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_deposits(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'deposits';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(deposit_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- PRIMARY KEY'
+ ',shard INT8 NOT NULL'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub) ON DELETE CASCADE
+ ',known_coin_id INT8 NOT NULL' -- REFERENCES known_coins (known_coin_id) ON DELETE CASCADE' --- FIXME: column needed???
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',wallet_timestamp INT8 NOT NULL'
+ ',exchange_timestamp INT8 NOT NULL'
+ ',refund_deadline INT8 NOT NULL'
+ ',wire_deadline INT8 NOT NULL'
+ ',merchant_pub BYTEA NOT NULL CHECK (LENGTH(merchant_pub)=32)'
+ ',h_contract_terms BYTEA NOT NULL CHECK (LENGTH(h_contract_terms)=64)'
+ ',coin_sig BYTEA NOT NULL CHECK (LENGTH(coin_sig)=64)'
+ ',wire_salt BYTEA NOT NULL CHECK (LENGTH(wire_salt)=16)'
+ ',wire_target_h_payto BYTEA CHECK (LENGTH(wire_target_h_payto)=32)'
+ ',done BOOLEAN NOT NULL DEFAULT FALSE'
+ ',extension_blocked BOOLEAN NOT NULL DEFAULT FALSE'
+ ',extension_details_serial_id INT8' -- REFERENCES extension_details (extension_details_serial_id) ON DELETE CASCADE'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (coin_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
+ 'ON ' || table_name || ' '
+ '(coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_deposits_by_ready(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_deposits_by_ready(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'deposits_by_ready';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(wire_deadline INT8 NOT NULL'
+ ',shard INT8 NOT NULL'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)'
+ ',deposit_serial_id INT8'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY RANGE (wire_deadline)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_main_index '
+ 'ON ' || table_name || ' '
+ '(wire_deadline ASC, shard ASC, coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_deposits_for_matching(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_deposits_for_matching(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'deposits_for_matching';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(refund_deadline INT8 NOT NULL'
+ ',merchant_pub BYTEA NOT NULL CHECK (LENGTH(merchant_pub)=32)'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub) ON DELETE CASCADE
+ ',deposit_serial_id INT8'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY RANGE (refund_deadline)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_main_index '
+ 'ON ' || table_name || ' '
+ '(refund_deadline ASC, merchant_pub, coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_history_requests(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_history_requests(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'history_requests';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(history_request_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE'
+ ',reserve_pub BYTEA NOT NULL CHECK (LENGTH(reserve_pub)=32)' -- REFERENCES reserves(reserve_pub) ON DELETE CASCADE
+ ',request_timestamp INT8 NOT NULL'
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',history_fee_val INT8 NOT NULL'
+ ',history_fee_frac INT4 NOT NULL'
+ ',PRIMARY KEY (reserve_pub,request_timestamp)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_pub)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_known_coins(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_known_coins(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR default 'known_coins';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(known_coin_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',denominations_serial INT8 NOT NULL' -- REFERENCES denominations (denominations_serial) ON DELETE CASCADE'
+ ',coin_pub BYTEA NOT NULL PRIMARY KEY CHECK (LENGTH(coin_pub)=32)'
+ ',age_commitment_hash BYTEA CHECK (LENGTH(age_commitment_hash)=32)'
+ ',denom_sig BYTEA NOT NULL'
+ ',remaining_val INT8 NOT NULL DEFAULT(0)'
+ ',remaining_frac INT4 NOT NULL DEFAULT(0)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (coin_pub)' -- FIXME: or include denominations_serial? or multi-level partitioning?;
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+END
+$$;
+
+
+--
+-- Name: create_table_prewire(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_prewire(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'prewire';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(prewire_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY PRIMARY KEY'
+ ',wire_method TEXT NOT NULL'
+ ',finished BOOLEAN NOT NULL DEFAULT false'
+ ',failed BOOLEAN NOT NULL DEFAULT false'
+ ',buf BYTEA NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (prewire_uuid)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_finished_index '
+ 'ON ' || table_name || ' '
+ '(finished);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_finished_index '
+ 'IS ' || quote_literal('for gc_prewire') || ';'
+ );
+ -- FIXME: find a way to combine these two indices?
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_failed_finished_index '
+ 'ON ' || table_name || ' '
+ '(failed,finished);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_failed_finished_index '
+ 'IS ' || quote_literal('for wire_prepare_data_get') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_purse_deposits(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_purse_deposits(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'purse_deposits';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(purse_deposit_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE
+ ',partner_serial_id INT8' -- REFERENCES partners(partner_serial_id) ON DELETE CASCADE'
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
+ ',coin_pub BYTEA NOT NULL' -- REFERENCES known_coins (coin_pub) ON DELETE CASCADE'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',coin_sig BYTEA NOT NULL CHECK(LENGTH(coin_sig)=64)'
+ ',PRIMARY KEY (purse_pub,coin_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by coin_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub '
+ 'ON ' || table_name || ' '
+ '(coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_purse_merges(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_purse_merges(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'purse_merges';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(purse_merge_request_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY '-- UNIQUE
+ ',partner_serial_id INT8' -- REFERENCES partners(partner_serial_id) ON DELETE CASCADE
+ ',reserve_pub BYTEA NOT NULL CHECK(length(reserve_pub)=32)'--REFERENCES reserves (reserve_pub) ON DELETE CASCADE
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)' --REFERENCES purse_requests (purse_pub) ON DELETE CASCADE
+ ',merge_sig BYTEA NOT NULL CHECK (LENGTH(merge_sig)=64)'
+ ',merge_timestamp INT8 NOT NULL'
+ ',PRIMARY KEY (purse_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by reserve_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_reserve_pub '
+ 'ON ' || table_name || ' '
+ '(reserve_pub);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_reserve_pub '
+ 'IS ' || quote_literal('needed in reserve history computation') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_purse_refunds(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_purse_refunds(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'purse_refunds';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(purse_refunds_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
+ ',PRIMARY KEY (purse_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+END
+$$;
+
+
+--
+-- Name: create_table_purse_requests(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_purse_requests(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'purse_requests';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(purse_requests_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',purse_pub BYTEA NOT NULL CHECK (LENGTH(purse_pub)=32)'
+ ',merge_pub BYTEA NOT NULL CHECK (LENGTH(merge_pub)=32)'
+ ',purse_creation INT8 NOT NULL'
+ ',purse_expiration INT8 NOT NULL'
+ ',h_contract_terms BYTEA NOT NULL CHECK (LENGTH(h_contract_terms)=64)'
+ ',age_limit INT4 NOT NULL'
+ ',flags INT4 NOT NULL'
+ ',refunded BOOLEAN NOT NULL DEFAULT(FALSE)'
+ ',finished BOOLEAN NOT NULL DEFAULT(FALSE)'
+ ',in_reserve_quota BOOLEAN NOT NULL DEFAULT(FALSE)'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',purse_fee_val INT8 NOT NULL'
+ ',purse_fee_frac INT4 NOT NULL'
+ ',balance_val INT8 NOT NULL DEFAULT (0)'
+ ',balance_frac INT4 NOT NULL DEFAULT (0)'
+ ',purse_sig BYTEA NOT NULL CHECK(LENGTH(purse_sig)=64)'
+ ',PRIMARY KEY (purse_pub)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by merge_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_merge_pub '
+ 'ON ' || table_name || ' '
+ '(merge_pub);'
+ );
+
+ -- FIXME: drop index on master (crosses shards)?
+ -- Or use materialized index? (needed?)
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_purse_expiration '
+ 'ON ' || table_name || ' '
+ '(purse_expiration);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_recoup(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_recoup(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'recoup';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(recoup_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub)
+ ',coin_sig BYTEA NOT NULL CHECK(LENGTH(coin_sig)=64)'
+ ',coin_blind BYTEA NOT NULL CHECK(LENGTH(coin_blind)=32)'
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',recoup_timestamp INT8 NOT NULL'
+ ',reserve_out_serial_id INT8 NOT NULL' -- REFERENCES reserves_out (reserve_out_serial_id) ON DELETE CASCADE'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (coin_pub);'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
+ 'ON ' || table_name || ' '
+ '(coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_recoup_by_reserve(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_recoup_by_reserve(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'recoup_by_reserve';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(reserve_out_serial_id INT8 NOT NULL' -- REFERENCES reserves (reserve_out_serial_id) ON DELETE CASCADE
+ ',coin_pub BYTEA CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub)
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_out_serial_id)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_main_index '
+ 'ON ' || table_name || ' '
+ '(reserve_out_serial_id);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_recoup_refresh(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_recoup_refresh(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'recoup_refresh';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(recoup_refresh_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub)
+ ',known_coin_id BIGINT NOT NULL' -- REFERENCES known_coins (known_coin_id) ON DELETE CASCADE
+ ',coin_sig BYTEA NOT NULL CHECK(LENGTH(coin_sig)=64)'
+ ',coin_blind BYTEA NOT NULL CHECK(LENGTH(coin_blind)=32)'
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',recoup_timestamp INT8 NOT NULL'
+ ',rrc_serial INT8 NOT NULL' -- REFERENCES refresh_revealed_coins (rrc_serial) ON DELETE CASCADE -- UNIQUE'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (coin_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: any query using this index will be slow. Materialize index or change query?
+ -- Also: which query uses this index?
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_rrc_serial_index '
+ 'ON ' || table_name || ' '
+ '(rrc_serial);'
+ );
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
+ 'ON ' || table_name || ' '
+ '(coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_refresh_commitments(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_refresh_commitments(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'refresh_commitments';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(melt_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',rc BYTEA PRIMARY KEY CHECK (LENGTH(rc)=64)'
+ ',old_coin_pub BYTEA NOT NULL' -- REFERENCES known_coins (coin_pub) ON DELETE CASCADE'
+ ',old_coin_sig BYTEA NOT NULL CHECK(LENGTH(old_coin_sig)=64)'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',noreveal_index INT4 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (rc)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- Note: index spans partitions, may need to be materialized.
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_old_coin_pub_index '
+ 'ON ' || table_name || ' '
+ '(old_coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_refresh_revealed_coins(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_refresh_revealed_coins(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'refresh_revealed_coins';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(rrc_serial BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',melt_serial_id INT8 NOT NULL' -- REFERENCES refresh_commitments (melt_serial_id) ON DELETE CASCADE'
+ ',freshcoin_index INT4 NOT NULL'
+ ',link_sig BYTEA NOT NULL CHECK(LENGTH(link_sig)=64)'
+ ',denominations_serial INT8 NOT NULL' -- REFERENCES denominations (denominations_serial) ON DELETE CASCADE'
+ ',coin_ev BYTEA NOT NULL' -- UNIQUE'
+ ',h_coin_ev BYTEA NOT NULL CHECK(LENGTH(h_coin_ev)=64)' -- UNIQUE'
+ ',ev_sig BYTEA NOT NULL'
+ ',ewv BYTEA NOT NULL'
+ -- ,PRIMARY KEY (melt_serial_id, freshcoin_index) -- done per shard
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (melt_serial_id)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_coins_by_melt_serial_id_index '
+ 'ON ' || table_name || ' '
+ '(melt_serial_id);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_refresh_transfer_keys(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_refresh_transfer_keys(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'refresh_transfer_keys';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(rtc_serial BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',melt_serial_id INT8 PRIMARY KEY' -- REFERENCES refresh_commitments (melt_serial_id) ON DELETE CASCADE'
+ ',transfer_pub BYTEA NOT NULL CHECK(LENGTH(transfer_pub)=32)'
+ ',transfer_privs BYTEA NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (melt_serial_id)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_refunds(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_refunds(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'refunds';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(refund_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',coin_pub BYTEA NOT NULL CHECK (LENGTH(coin_pub)=32)' -- REFERENCES known_coins (coin_pub) ON DELETE CASCADE
+ ',deposit_serial_id INT8 NOT NULL' -- REFERENCES deposits (deposit_serial_id) ON DELETE CASCADE'
+ ',merchant_sig BYTEA NOT NULL CHECK(LENGTH(merchant_sig)=64)'
+ ',rtransaction_id INT8 NOT NULL'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ -- ,PRIMARY KEY (deposit_serial_id, rtransaction_id) -- done per shard!
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (coin_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_coin_pub_index '
+ 'ON ' || table_name || ' '
+ '(coin_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_reserves(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_reserves(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'reserves';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(reserve_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY'
+ ',reserve_pub BYTEA PRIMARY KEY CHECK(LENGTH(reserve_pub)=32)'
+ ',current_balance_val INT8 NOT NULL DEFAULT(0)'
+ ',current_balance_frac INT4 NOT NULL DEFAULT(0)'
+ ',purses_active INT8 NOT NULL DEFAULT(0)'
+ ',purses_allowed INT8 NOT NULL DEFAULT(0)'
+ ',kyc_required BOOLEAN NOT NULL DEFAULT(FALSE)'
+ ',kyc_passed BOOLEAN NOT NULL DEFAULT(FALSE)'
+ ',max_age INT4 NOT NULL DEFAULT(120)'
+ ',expiration_date INT8 NOT NULL'
+ ',gc_date INT8 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_expiration_index '
+ 'ON ' || table_name || ' '
+ '(expiration_date'
+ ',current_balance_val'
+ ',current_balance_frac'
+ ');'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_expiration_index '
+ 'IS ' || quote_literal('used in get_expired_reserves') || ';'
+ );
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_uuid_index '
+ 'ON ' || table_name || ' '
+ '(reserve_uuid);'
+ );
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_gc_date_index '
+ 'ON ' || table_name || ' '
+ '(gc_date);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_gc_date_index '
+ 'IS ' || quote_literal('for reserve garbage collection') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_reserves_close(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_reserves_close(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR default 'reserves_close';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(close_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE / PRIMARY KEY'
+ ',reserve_pub BYTEA NOT NULL' -- REFERENCES reserves (reserve_pub) ON DELETE CASCADE'
+ ',execution_date INT8 NOT NULL'
+ ',wtid BYTEA NOT NULL CHECK (LENGTH(wtid)=32)'
+ ',wire_target_h_payto BYTEA CHECK (LENGTH(wire_target_h_payto)=32)'
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',closing_fee_val INT8 NOT NULL'
+ ',closing_fee_frac INT4 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_close_uuid_index '
+ 'ON ' || table_name || ' '
+ '(close_uuid);'
+ );
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_pub_index '
+ 'ON ' || table_name || ' '
+ '(reserve_pub);'
+ );
+END
+$$;
+
+
+--
+-- Name: create_table_reserves_in(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_reserves_in(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR default 'reserves_in';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(reserve_in_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',reserve_pub BYTEA PRIMARY KEY' -- REFERENCES reserves (reserve_pub) ON DELETE CASCADE'
+ ',wire_reference INT8 NOT NULL'
+ ',credit_val INT8 NOT NULL'
+ ',credit_frac INT4 NOT NULL'
+ ',wire_source_h_payto BYTEA CHECK (LENGTH(wire_source_h_payto)=32)'
+ ',exchange_account_section TEXT NOT NULL'
+ ',execution_date INT8 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (reserve_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_in_serial_id_index '
+ 'ON ' || table_name || ' '
+ '(reserve_in_serial_id);'
+ );
+ -- FIXME: where do we need this index? Can we do better?
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_exch_accnt_section_execution_date_idx '
+ 'ON ' || table_name || ' '
+ '(exchange_account_section '
+ ',execution_date'
+ ');'
+ );
+ -- FIXME: where do we need this index? Can we do better?
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_exch_accnt_reserve_in_serial_id_idx '
+ 'ON ' || table_name || ' '
+ '(exchange_account_section,'
+ 'reserve_in_serial_id DESC'
+ ');'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_reserves_out(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_reserves_out(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR default 'reserves_out';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(reserve_out_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',h_blind_ev BYTEA CHECK (LENGTH(h_blind_ev)=64) UNIQUE'
+ ',denominations_serial INT8 NOT NULL' -- REFERENCES denominations (denominations_serial)'
+ ',denom_sig BYTEA NOT NULL'
+ ',reserve_uuid INT8 NOT NULL' -- REFERENCES reserves (reserve_uuid) ON DELETE CASCADE'
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',execution_date INT8 NOT NULL'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ') %s ;'
+ ,'reserves_out'
+ ,'PARTITION BY HASH (h_blind_ev)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_out_serial_id_index '
+ 'ON ' || table_name || ' '
+ '(reserve_out_serial_id);'
+ );
+ -- FIXME: change query to use reserves_out_by_reserve instead and materialize execution_date there as well???
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_uuid_and_execution_date_index '
+ 'ON ' || table_name || ' '
+ '(reserve_uuid, execution_date);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_by_reserve_uuid_and_execution_date_index '
+ 'IS ' || quote_literal('for get_reserves_out and exchange_do_withdraw_limit_check') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_reserves_out_by_reserve(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_reserves_out_by_reserve(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'reserves_out_by_reserve';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(reserve_uuid INT8 NOT NULL' -- REFERENCES reserves (reserve_uuid) ON DELETE CASCADE
+ ',h_blind_ev BYTEA CHECK (LENGTH(h_blind_ev)=64)'
+ ') %s '
+ ,table_name
+ ,'PARTITION BY HASH (reserve_uuid)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_main_index '
+ 'ON ' || table_name || ' '
+ '(reserve_uuid);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_wad_in_entries(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wad_in_entries(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'wad_in_entries';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(wad_in_entry_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',wad_in_serial_id INT8' -- REFERENCES wads_in (wad_in_serial_id) ON DELETE CASCADE
+ ',reserve_pub BYTEA NOT NULL CHECK(LENGTH(reserve_pub)=32)'
+ ',purse_pub BYTEA PRIMARY KEY CHECK(LENGTH(purse_pub)=32)'
+ ',h_contract BYTEA NOT NULL CHECK(LENGTH(h_contract)=64)'
+ ',purse_expiration INT8 NOT NULL'
+ ',merge_timestamp INT8 NOT NULL'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',wad_fee_val INT8 NOT NULL'
+ ',wad_fee_frac INT4 NOT NULL'
+ ',deposit_fees_val INT8 NOT NULL'
+ ',deposit_fees_frac INT4 NOT NULL'
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',purse_sig BYTEA NOT NULL CHECK (LENGTH(purse_sig)=64)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by reserve_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_reserve_pub '
+ 'ON ' || table_name || ' '
+ '(reserve_pub);'
+ );
+ EXECUTE FORMAT (
+ 'COMMENT ON INDEX ' || table_name || '_reserve_pub '
+ 'IS ' || quote_literal('needed in reserve history computation') || ';'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_wad_out_entries(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wad_out_entries(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'wad_out_entries';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(wad_out_entry_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',wad_out_serial_id INT8' -- REFERENCES wads_out (wad_out_serial_id) ON DELETE CASCADE
+ ',reserve_pub BYTEA NOT NULL CHECK(LENGTH(reserve_pub)=32)'
+ ',purse_pub BYTEA PRIMARY KEY CHECK(LENGTH(purse_pub)=32)'
+ ',h_contract BYTEA NOT NULL CHECK(LENGTH(h_contract)=64)'
+ ',purse_expiration INT8 NOT NULL'
+ ',merge_timestamp INT8 NOT NULL'
+ ',amount_with_fee_val INT8 NOT NULL'
+ ',amount_with_fee_frac INT4 NOT NULL'
+ ',wad_fee_val INT8 NOT NULL'
+ ',wad_fee_frac INT4 NOT NULL'
+ ',deposit_fees_val INT8 NOT NULL'
+ ',deposit_fees_frac INT4 NOT NULL'
+ ',reserve_sig BYTEA NOT NULL CHECK (LENGTH(reserve_sig)=64)'
+ ',purse_sig BYTEA NOT NULL CHECK (LENGTH(purse_sig)=64)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (purse_pub)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ -- FIXME: change to materialized index by reserve_pub!
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_reserve_pub '
+ 'ON ' || table_name || ' '
+ '(reserve_pub);'
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_wads_in(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wads_in(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'wads_in';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(wad_in_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',wad_id BYTEA PRIMARY KEY CHECK (LENGTH(wad_id)=24)'
+ ',origin_exchange_url TEXT NOT NULL'
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',arrival_time INT8 NOT NULL'
+ ',UNIQUE (wad_id, origin_exchange_url)'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (wad_id)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_wads_out(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wads_out(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'wads_out';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I '
+ '(wad_out_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' --UNIQUE
+ ',wad_id BYTEA PRIMARY KEY CHECK (LENGTH(wad_id)=24)'
+ ',partner_serial_id INT8 NOT NULL' -- REFERENCES partners(partner_serial_id) ON DELETE CASCADE
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ',execution_time INT8 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (wad_id)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: create_table_wire_out(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wire_out(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ table_name VARCHAR DEFAULT 'wire_out';
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(wireout_uuid BIGINT GENERATED BY DEFAULT AS IDENTITY' -- PRIMARY KEY'
+ ',execution_date INT8 NOT NULL'
+ ',wtid_raw BYTEA UNIQUE NOT NULL CHECK (LENGTH(wtid_raw)=32)'
+ ',wire_target_h_payto BYTEA CHECK (LENGTH(wire_target_h_payto)=32)'
+ ',exchange_account_section TEXT NOT NULL'
+ ',amount_val INT8 NOT NULL'
+ ',amount_frac INT4 NOT NULL'
+ ') %s ;'
+ ,table_name
+ ,'PARTITION BY HASH (wtid_raw)'
+ ,shard_suffix
+ );
+
+ table_name = concat_ws('_', table_name, shard_suffix);
+
+ EXECUTE FORMAT (
+ 'CREATE INDEX IF NOT EXISTS ' || table_name || '_by_wire_target_h_payto_index '
+ 'ON ' || table_name || ' '
+ '(wire_target_h_payto);'
+ );
+
+
+END
+$$;
+
+
+--
+-- Name: create_table_wire_targets(character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.create_table_wire_targets(shard_suffix character varying DEFAULT NULL::character varying) RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ PERFORM create_partitioned_table(
+ 'CREATE TABLE IF NOT EXISTS %I'
+ '(wire_target_serial_id BIGINT GENERATED BY DEFAULT AS IDENTITY' -- UNIQUE'
+ ',wire_target_h_payto BYTEA PRIMARY KEY CHECK (LENGTH(wire_target_h_payto)=32)'
+ ',payto_uri VARCHAR NOT NULL'
+ ',kyc_ok BOOLEAN NOT NULL DEFAULT (FALSE)'
+ ',external_id VARCHAR'
+ ') %s ;'
+ ,'wire_targets'
+ ,'PARTITION BY HASH (wire_target_h_payto)'
+ ,shard_suffix
+ );
+
+END
+$$;
+
+
+--
+-- Name: defer_wire_out(); Type: PROCEDURE; Schema: public; Owner: -
+--
+
+CREATE PROCEDURE public.defer_wire_out()
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+IF EXISTS (
+ SELECT 1
+ FROM information_Schema.constraint_column_usage
+ WHERE table_name='wire_out'
+ AND constraint_name='wire_out_ref')
+THEN
+ SET CONSTRAINTS wire_out_ref DEFERRED;
+END IF;
+
+END $$;
+
+
+--
+-- Name: deposits_delete_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.deposits_delete_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ was_ready BOOLEAN;
+BEGIN
+ was_ready = NOT (OLD.done OR OLD.extension_blocked);
+
+ IF (was_ready)
+ THEN
+ DELETE FROM deposits_by_ready
+ WHERE wire_deadline = OLD.wire_deadline
+ AND shard = OLD.shard
+ AND coin_pub = OLD.coin_pub
+ AND deposit_serial_id = OLD.deposit_serial_id;
+ DELETE FROM deposits_for_matching
+ WHERE refund_deadline = OLD.refund_deadline
+ AND merchant_pub = OLD.merchant_pub
+ AND coin_pub = OLD.coin_pub
+ AND deposit_serial_id = OLD.deposit_serial_id;
+ END IF;
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION deposits_delete_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.deposits_delete_trigger() IS 'Replicate deposit deletions into materialized indices.';
+
+
+--
+-- Name: deposits_insert_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.deposits_insert_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ is_ready BOOLEAN;
+BEGIN
+ is_ready = NOT (NEW.done OR NEW.extension_blocked);
+
+ IF (is_ready)
+ THEN
+ INSERT INTO deposits_by_ready
+ (wire_deadline
+ ,shard
+ ,coin_pub
+ ,deposit_serial_id)
+ VALUES
+ (NEW.wire_deadline
+ ,NEW.shard
+ ,NEW.coin_pub
+ ,NEW.deposit_serial_id);
+ INSERT INTO deposits_for_matching
+ (refund_deadline
+ ,merchant_pub
+ ,coin_pub
+ ,deposit_serial_id)
+ VALUES
+ (NEW.refund_deadline
+ ,NEW.merchant_pub
+ ,NEW.coin_pub
+ ,NEW.deposit_serial_id);
+ END IF;
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION deposits_insert_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.deposits_insert_trigger() IS 'Replicate deposit inserts into materialized indices.';
+
+
+--
+-- Name: deposits_update_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.deposits_update_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ was_ready BOOLEAN;
+DECLARE
+ is_ready BOOLEAN;
+BEGIN
+ was_ready = NOT (OLD.done OR OLD.extension_blocked);
+ is_ready = NOT (NEW.done OR NEW.extension_blocked);
+ IF (was_ready AND NOT is_ready)
+ THEN
+ DELETE FROM deposits_by_ready
+ WHERE wire_deadline = OLD.wire_deadline
+ AND shard = OLD.shard
+ AND coin_pub = OLD.coin_pub
+ AND deposit_serial_id = OLD.deposit_serial_id;
+ DELETE FROM deposits_for_matching
+ WHERE refund_deadline = OLD.refund_deadline
+ AND merchant_pub = OLD.merchant_pub
+ AND coin_pub = OLD.coin_pub
+ AND deposit_serial_id = OLD.deposit_serial_id;
+ END IF;
+ IF (is_ready AND NOT was_ready)
+ THEN
+ INSERT INTO deposits_by_ready
+ (wire_deadline
+ ,shard
+ ,coin_pub
+ ,deposit_serial_id)
+ VALUES
+ (NEW.wire_deadline
+ ,NEW.shard
+ ,NEW.coin_pub
+ ,NEW.deposit_serial_id);
+ INSERT INTO deposits_for_matching
+ (refund_deadline
+ ,merchant_pub
+ ,coin_pub
+ ,deposit_serial_id)
+ VALUES
+ (NEW.refund_deadline
+ ,NEW.merchant_pub
+ ,NEW.coin_pub
+ ,NEW.deposit_serial_id);
+ END IF;
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION deposits_update_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.deposits_update_trigger() IS 'Replicate deposits changes into materialized indices.';
+
+
+--
+-- Name: detach_default_partitions(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.detach_default_partitions() RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ RAISE NOTICE 'Detaching all default table partitions';
+
+ ALTER TABLE IF EXISTS wire_targets
+ DETACH PARTITION wire_targets_default;
+
+ ALTER TABLE IF EXISTS reserves
+ DETACH PARTITION reserves_default;
+
+ ALTER TABLE IF EXISTS reserves_in
+ DETACH PARTITION reserves_in_default;
+
+ ALTER TABLE IF EXISTS reserves_close
+ DETACH PARTITION reserves_close_default;
+
+ ALTER TABLE IF EXISTS reserves_out
+ DETACH PARTITION reserves_out_default;
+
+ ALTER TABLE IF EXISTS reserves_out_by_reserve
+ DETACH PARTITION reserves_out_by_reserve_default;
+
+ ALTER TABLE IF EXISTS known_coins
+ DETACH PARTITION known_coins_default;
+
+ ALTER TABLE IF EXISTS refresh_commitments
+ DETACH PARTITION refresh_commitments_default;
+
+ ALTER TABLE IF EXISTS refresh_revealed_coins
+ DETACH PARTITION refresh_revealed_coins_default;
+
+ ALTER TABLE IF EXISTS refresh_transfer_keys
+ DETACH PARTITION refresh_transfer_keys_default;
+
+ ALTER TABLE IF EXISTS deposits
+ DETACH PARTITION deposits_default;
+
+--- TODO range partitioning
+-- ALTER TABLE IF EXISTS deposits_by_ready
+-- DETACH PARTITION deposits_by_ready_default;
+--
+-- ALTER TABLE IF EXISTS deposits_for_matching
+-- DETACH PARTITION deposits_default_for_matching_default;
+
+ ALTER TABLE IF EXISTS refunds
+ DETACH PARTITION refunds_default;
+
+ ALTER TABLE IF EXISTS wire_out
+ DETACH PARTITION wire_out_default;
+
+ ALTER TABLE IF EXISTS aggregation_transient
+ DETACH PARTITION aggregation_transient_default;
+
+ ALTER TABLE IF EXISTS aggregation_tracking
+ DETACH PARTITION aggregation_tracking_default;
+
+ ALTER TABLE IF EXISTS recoup
+ DETACH PARTITION recoup_default;
+
+ ALTER TABLE IF EXISTS recoup_by_reserve
+ DETACH PARTITION recoup_by_reserve_default;
+
+ ALTER TABLE IF EXISTS recoup_refresh
+ DETACH PARTITION recoup_refresh_default;
+
+ ALTER TABLE IF EXISTS prewire
+ DETACH PARTITION prewire_default;
+
+ ALTER TABLE IF EXISTS cs_nonce_locks
+ DETACH partition cs_nonce_locks_default;
+
+ ALTER TABLE IF EXISTS purse_requests
+ DETACH partition purse_requests_default;
+
+ ALTER TABLE IF EXISTS purse_refunds
+ DETACH partition purse_refunds_default;
+
+ ALTER TABLE IF EXISTS purse_merges
+ DETACH partition purse_merges_default;
+
+ ALTER TABLE IF EXISTS account_merges
+ DETACH partition account_merges_default;
+
+ ALTER TABLE IF EXISTS contracts
+ DETACH partition contracts_default;
+
+ ALTER TABLE IF EXISTS history_requests
+ DETACH partition history_requests_default;
+
+ ALTER TABLE IF EXISTS close_requests
+ DETACH partition close_requests_default;
+
+ ALTER TABLE IF EXISTS purse_deposits
+ DETACH partition purse_deposits_default;
+
+ ALTER TABLE IF EXISTS wad_out_entries
+ DETACH partition wad_out_entries_default;
+
+ ALTER TABLE IF EXISTS wads_in
+ DETACH partition wads_in_default;
+
+ ALTER TABLE IF EXISTS wad_in_entries
+ DETACH partition wad_in_entries_default;
+END
+$$;
+
+
+--
+-- Name: FUNCTION detach_default_partitions(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.detach_default_partitions() IS 'We need to drop default and create new one before deleting the default partitions
+ otherwise constraints get lost too. Might be needed in shardig too';
+
+
+--
+-- Name: drop_default_partitions(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.drop_default_partitions() RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ RAISE NOTICE 'Dropping default table partitions';
+
+ DROP TABLE IF EXISTS wire_targets_default;
+ DROP TABLE IF EXISTS reserves_default;
+ DROP TABLE IF EXISTS reserves_in_default;
+ DROP TABLE IF EXISTS reserves_close_default;
+ DROP TABLE IF EXISTS reserves_out_default;
+ DROP TABLE IF EXISTS reserves_out_by_reserve_default;
+ DROP TABLE IF EXISTS known_coins_default;
+ DROP TABLE IF EXISTS refresh_commitments_default;
+ DROP TABLE IF EXISTS refresh_revealed_coins_default;
+ DROP TABLE IF EXISTS refresh_transfer_keys_default;
+ DROP TABLE IF EXISTS deposits_default;
+--DROP TABLE IF EXISTS deposits_by_ready_default;
+--DROP TABLE IF EXISTS deposits_for_matching_default;
+ DROP TABLE IF EXISTS refunds_default;
+ DROP TABLE IF EXISTS wire_out_default;
+ DROP TABLE IF EXISTS aggregation_transient_default;
+ DROP TABLE IF EXISTS aggregation_tracking_default;
+ DROP TABLE IF EXISTS recoup_default;
+ DROP TABLE IF EXISTS recoup_by_reserve_default;
+ DROP TABLE IF EXISTS recoup_refresh_default;
+ DROP TABLE IF EXISTS prewire_default;
+ DROP TABLE IF EXISTS cs_nonce_locks_default;
+
+ DROP TABLE IF EXISTS purse_requests_default;
+ DROP TABLE IF EXISTS purse_refunds_default;
+ DROP TABLE IF EXISTS purse_merges_default;
+ DROP TABLE IF EXISTS account_merges_default;
+ DROP TABLE IF EXISTS contracts_default;
+ DROP TABLE IF EXISTS history_requests_default;
+ DROP TABLE IF EXISTS close_requests_default;
+ DROP TABLE IF EXISTS purse_deposits_default;
+ DROP TABLE IF EXISTS wad_out_entries_default;
+ DROP TABLE IF EXISTS wads_in_default;
+ DROP TABLE IF EXISTS wad_in_entries_default;
+
+END
+$$;
+
+
+--
+-- Name: FUNCTION drop_default_partitions(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.drop_default_partitions() IS 'Drop all default partitions once other partitions are attached.
+ Might be needed in sharding too.';
+
+
+--
+-- Name: exchange_do_account_merge(bytea, bytea, bytea); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_account_merge(in_purse_pub bytea, in_reserve_pub bytea, in_reserve_sig bytea, OUT out_balance_ok boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ -- FIXME: function/API is dead! Do DCE?
+END $$;
+
+
+--
+-- Name: exchange_do_batch_withdraw(bigint, integer, bytea, bigint, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_batch_withdraw(amount_val bigint, amount_frac integer, rpub bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ reserve_gc INT8;
+DECLARE
+ reserve_val INT8;
+DECLARE
+ reserve_frac INT4;
+BEGIN
+-- Shards: reserves by reserve_pub (SELECT)
+-- reserves_out (INSERT, with CONFLICT detection) by wih
+-- reserves by reserve_pub (UPDATE)
+-- reserves_in by reserve_pub (SELECT)
+-- wire_targets by wire_target_h_payto
+
+SELECT
+ current_balance_val
+ ,current_balance_frac
+ ,gc_date
+ ,reserve_uuid
+ INTO
+ reserve_val
+ ,reserve_frac
+ ,reserve_gc
+ ,ruuid
+ FROM reserves
+ WHERE reserves.reserve_pub=rpub;
+
+IF NOT FOUND
+THEN
+ -- reserve unknown
+ reserve_found=FALSE;
+ balance_ok=FALSE;
+ kycok=FALSE;
+ account_uuid=0;
+ ruuid=2;
+ RETURN;
+END IF;
+
+-- Check reserve balance is sufficient.
+IF (reserve_val > amount_val)
+THEN
+ IF (reserve_frac >= amount_frac)
+ THEN
+ reserve_val=reserve_val - amount_val;
+ reserve_frac=reserve_frac - amount_frac;
+ ELSE
+ reserve_val=reserve_val - amount_val - 1;
+ reserve_frac=reserve_frac + 100000000 - amount_frac;
+ END IF;
+ELSE
+ IF (reserve_val = amount_val) AND (reserve_frac >= amount_frac)
+ THEN
+ reserve_val=0;
+ reserve_frac=reserve_frac - amount_frac;
+ ELSE
+ reserve_found=TRUE;
+ balance_ok=FALSE;
+ kycok=FALSE; -- we do not really know or care
+ account_uuid=0;
+ RETURN;
+ END IF;
+END IF;
+
+-- Calculate new expiration dates.
+min_reserve_gc=GREATEST(min_reserve_gc,reserve_gc);
+
+-- Update reserve balance.
+UPDATE reserves SET
+ gc_date=min_reserve_gc
+ ,current_balance_val=reserve_val
+ ,current_balance_frac=reserve_frac
+WHERE
+ reserves.reserve_pub=rpub;
+
+reserve_found=TRUE;
+balance_ok=TRUE;
+
+
+-- Obtain KYC status based on the last wire transfer into
+-- this reserve. FIXME: likely not adequate for reserves that got P2P transfers!
+-- SELECT
+-- kyc_ok
+-- ,wire_target_serial_id
+-- INTO
+-- kycok
+-- ,account_uuid
+-- FROM reserves_in
+-- JOIN wire_targets ON (wire_source_h_payto = wire_target_h_payto)
+-- WHERE reserve_pub=rpub
+-- LIMIT 1; -- limit 1 should not be required (without p2p transfers)
+
+WITH reserves_in AS materialized (
+ SELECT wire_source_h_payto
+ FROM reserves_in WHERE
+ reserve_pub=rpub
+)
+SELECT
+ kyc_ok
+ ,wire_target_serial_id
+INTO
+ kycok
+ ,account_uuid
+FROM wire_targets
+ WHERE wire_target_h_payto = (
+ SELECT wire_source_h_payto
+ FROM reserves_in
+ );
+
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_batch_withdraw(amount_val bigint, amount_frac integer, rpub bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_batch_withdraw(amount_val bigint, amount_frac integer, rpub bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint) IS 'Checks whether the reserve has sufficient balance for a withdraw operation (or the request is repeated and was previously approved) and if so updates the database with the result. Excludes storing the planchets.';
+
+
+--
+-- Name: exchange_do_batch_withdraw_insert(bytea, bigint, integer, bytea, bigint, bytea, bytea, bytea, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_batch_withdraw_insert(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, ruuid bigint, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, OUT out_denom_unknown boolean, OUT out_nonce_reuse boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ denom_serial INT8;
+BEGIN
+-- Shards: reserves by reserve_pub (SELECT)
+-- reserves_out (INSERT, with CONFLICT detection) by wih
+-- reserves by reserve_pub (UPDATE)
+-- reserves_in by reserve_pub (SELECT)
+-- wire_targets by wire_target_h_payto
+
+out_denom_unknown=TRUE;
+out_conflict=TRUE;
+out_nonce_reuse=TRUE;
+
+SELECT denominations_serial
+ INTO denom_serial
+ FROM denominations
+ WHERE denom_pub_hash=h_denom_pub;
+
+IF NOT FOUND
+THEN
+ -- denomination unknown, should be impossible!
+ out_denom_unknown=TRUE;
+ ASSERT false, 'denomination unknown';
+ RETURN;
+END IF;
+out_denom_unknown=FALSE;
+
+INSERT INTO reserves_out
+ (h_blind_ev
+ ,denominations_serial
+ ,denom_sig
+ ,reserve_uuid
+ ,reserve_sig
+ ,execution_date
+ ,amount_with_fee_val
+ ,amount_with_fee_frac)
+VALUES
+ (h_coin_envelope
+ ,denom_serial
+ ,denom_sig
+ ,ruuid
+ ,reserve_sig
+ ,now
+ ,amount_val
+ ,amount_frac)
+ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ out_conflict=TRUE;
+ RETURN;
+END IF;
+out_conflict=FALSE;
+
+-- Special actions needed for a CS withdraw?
+out_nonce_reuse=FALSE;
+IF NOT NULL cs_nonce
+THEN
+ -- Cache CS signature to prevent replays in the future
+ -- (and check if cached signature exists at the same time).
+ INSERT INTO cs_nonce_locks
+ (nonce
+ ,max_denomination_serial
+ ,op_hash)
+ VALUES
+ (cs_nonce
+ ,denom_serial
+ ,h_coin_envelope)
+ ON CONFLICT DO NOTHING;
+
+ IF NOT FOUND
+ THEN
+ -- See if the existing entry is identical.
+ SELECT 1
+ FROM cs_nonce_locks
+ WHERE nonce=cs_nonce
+ AND op_hash=h_coin_envelope;
+ IF NOT FOUND
+ THEN
+ out_nonce_reuse=TRUE;
+ ASSERT false, 'nonce reuse attempted by client';
+ RETURN;
+ END IF;
+ END IF;
+END IF;
+
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_batch_withdraw_insert(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, ruuid bigint, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, OUT out_denom_unknown boolean, OUT out_nonce_reuse boolean, OUT out_conflict boolean); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_batch_withdraw_insert(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, ruuid bigint, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, OUT out_denom_unknown boolean, OUT out_nonce_reuse boolean, OUT out_conflict boolean) IS 'Stores information about a planchet for a batch withdraw operation. Checks if the planchet already exists, and in that case indicates a conflict';
+
+
+--
+-- Name: exchange_do_close_request(bytea, bytea); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_close_request(in_reserve_pub bytea, in_reserve_sig bytea, OUT out_final_balance_val bigint, OUT out_final_balance_frac integer, OUT out_balance_ok boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ -- FIXME
+END $$;
+
+
+--
+-- Name: exchange_do_deposit(bigint, integer, bytea, bytea, bigint, bigint, bigint, bigint, bytea, character varying, bytea, bigint, bytea, bytea, bigint, boolean, character varying); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_deposit(in_amount_with_fee_val bigint, in_amount_with_fee_frac integer, in_h_contract_terms bytea, in_wire_salt bytea, in_wallet_timestamp bigint, in_exchange_timestamp bigint, in_refund_deadline bigint, in_wire_deadline bigint, in_merchant_pub bytea, in_receiver_wire_account character varying, in_h_payto bytea, in_known_coin_id bigint, in_coin_pub bytea, in_coin_sig bytea, in_shard bigint, in_extension_blocked boolean, in_extension_details character varying, OUT out_exchange_timestamp bigint, OUT out_balance_ok boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ wtsi INT8; -- wire target serial id
+DECLARE
+ xdi INT8; -- eXstension details serial id
+BEGIN
+-- Shards: INSERT extension_details (by extension_details_serial_id)
+-- INSERT wire_targets (by h_payto), on CONFLICT DO NOTHING;
+-- INSERT deposits (by coin_pub, shard), ON CONFLICT DO NOTHING;
+-- UPDATE known_coins (by coin_pub)
+
+IF NOT NULL in_extension_details
+THEN
+ INSERT INTO extension_details
+ (extension_options)
+ VALUES
+ (in_extension_details)
+ RETURNING extension_details_serial_id INTO xdi;
+ELSE
+ xdi=NULL;
+END IF;
+
+
+INSERT INTO wire_targets
+ (wire_target_h_payto
+ ,payto_uri)
+ VALUES
+ (in_h_payto
+ ,in_receiver_wire_account)
+ON CONFLICT DO NOTHING -- for CONFLICT ON (wire_target_h_payto)
+ RETURNING wire_target_serial_id INTO wtsi;
+
+IF NOT FOUND
+THEN
+ SELECT wire_target_serial_id
+ INTO wtsi
+ FROM wire_targets
+ WHERE wire_target_h_payto=in_h_payto;
+END IF;
+
+
+INSERT INTO deposits
+ (shard
+ ,coin_pub
+ ,known_coin_id
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ ,wallet_timestamp
+ ,exchange_timestamp
+ ,refund_deadline
+ ,wire_deadline
+ ,merchant_pub
+ ,h_contract_terms
+ ,coin_sig
+ ,wire_salt
+ ,wire_target_h_payto
+ ,extension_blocked
+ ,extension_details_serial_id
+ )
+ VALUES
+ (in_shard
+ ,in_coin_pub
+ ,in_known_coin_id
+ ,in_amount_with_fee_val
+ ,in_amount_with_fee_frac
+ ,in_wallet_timestamp
+ ,in_exchange_timestamp
+ ,in_refund_deadline
+ ,in_wire_deadline
+ ,in_merchant_pub
+ ,in_h_contract_terms
+ ,in_coin_sig
+ ,in_wire_salt
+ ,in_h_payto
+ ,in_extension_blocked
+ ,xdi)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: see if an identical record exists.
+ -- Note that by checking 'coin_sig', we implicitly check
+ -- identity over everything that the signature covers.
+ -- We do select over merchant_pub and wire_target_h_payto
+ -- primarily here to maximally use the existing index.
+ SELECT
+ exchange_timestamp
+ INTO
+ out_exchange_timestamp
+ FROM deposits
+ WHERE shard=in_shard
+ AND merchant_pub=in_merchant_pub
+ AND wire_target_h_payto=in_h_payto
+ AND coin_pub=in_coin_pub
+ AND coin_sig=in_coin_sig;
+
+ IF NOT FOUND
+ THEN
+ -- Deposit exists, but with differences. Not allowed.
+ out_balance_ok=FALSE;
+ out_conflict=TRUE;
+ RETURN;
+ END IF;
+
+ -- Idempotent request known, return success.
+ out_balance_ok=TRUE;
+ out_conflict=FALSE;
+
+ RETURN;
+END IF;
+
+
+out_exchange_timestamp=in_exchange_timestamp;
+
+-- Check and update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=remaining_frac-in_amount_with_fee_frac
+ + CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val-in_amount_with_fee_val
+ - CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub=in_coin_pub
+ AND ( (remaining_val > in_amount_with_fee_val) OR
+ ( (remaining_frac >= in_amount_with_fee_frac) AND
+ (remaining_val >= in_amount_with_fee_val) ) );
+
+IF NOT FOUND
+THEN
+ -- Insufficient balance.
+ out_balance_ok=FALSE;
+ out_conflict=FALSE;
+ RETURN;
+END IF;
+
+-- Everything fine, return success!
+out_balance_ok=TRUE;
+out_conflict=FALSE;
+
+END $$;
+
+
+--
+-- Name: exchange_do_expire_purse(bigint, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_expire_purse(in_start_time bigint, in_end_time bigint, OUT out_found boolean) RETURNS boolean
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ my_purse_pub BYTEA;
+DECLARE
+ my_deposit record;
+BEGIN
+
+SELECT purse_pub
+ INTO my_purse_pub
+ FROM purse_requests
+ WHERE (purse_expiration >= in_start_time) AND
+ (purse_expiration < in_end_time) AND
+ (NOT finished) AND
+ (NOT refunded)
+ ORDER BY purse_expiration ASC
+ LIMIT 1;
+out_found = FOUND;
+IF NOT FOUND
+THEN
+ RETURN;
+END IF;
+
+UPDATE purse_requests
+ SET refunded=TRUE,
+ finished=TRUE
+ WHERE purse_pub=my_purse_pub;
+
+INSERT INTO purse_refunds
+ (purse_pub)
+ VALUES
+ (my_purse_pub);
+
+-- restore balance to each coin deposited into the purse
+FOR my_deposit IN
+ SELECT coin_pub
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ FROM purse_deposits
+ WHERE purse_pub = my_purse_pub
+LOOP
+ UPDATE known_coins SET
+ remaining_frac=remaining_frac+my_deposit.amount_with_fee_frac
+ - CASE
+ WHEN remaining_frac+my_deposit.amount_with_fee_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val+my_deposit.amount_with_fee_val
+ + CASE
+ WHEN remaining_frac+my_deposit.amount_with_fee_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub = my_deposit.coin_pub;
+ END LOOP;
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_expire_purse(in_start_time bigint, in_end_time bigint, OUT out_found boolean); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_expire_purse(in_start_time bigint, in_end_time bigint, OUT out_found boolean) IS 'Finds an expired purse in the given time range and refunds the coins (if any).';
+
+
+--
+-- Name: exchange_do_gc(bigint, bigint); Type: PROCEDURE; Schema: public; Owner: -
+--
+
+CREATE PROCEDURE public.exchange_do_gc(in_ancient_date bigint, in_now bigint)
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ reserve_uuid_min INT8; -- minimum reserve UUID still alive
+DECLARE
+ melt_min INT8; -- minimum melt still alive
+DECLARE
+ coin_min INT8; -- minimum known_coin still alive
+DECLARE
+ deposit_min INT8; -- minimum deposit still alive
+DECLARE
+ reserve_out_min INT8; -- minimum reserve_out still alive
+DECLARE
+ denom_min INT8; -- minimum denomination still alive
+BEGIN
+
+DELETE FROM prewire
+ WHERE finished=TRUE;
+
+DELETE FROM wire_fee
+ WHERE end_date < in_ancient_date;
+
+-- TODO: use closing fee as threshold?
+DELETE FROM reserves
+ WHERE gc_date < in_now
+ AND current_balance_val = 0
+ AND current_balance_frac = 0;
+
+SELECT
+ reserve_out_serial_id
+ INTO
+ reserve_out_min
+ FROM reserves_out
+ ORDER BY reserve_out_serial_id ASC
+ LIMIT 1;
+
+DELETE FROM recoup
+ WHERE reserve_out_serial_id < reserve_out_min;
+-- FIXME: recoup_refresh lacks GC!
+
+SELECT
+ reserve_uuid
+ INTO
+ reserve_uuid_min
+ FROM reserves
+ ORDER BY reserve_uuid ASC
+ LIMIT 1;
+
+DELETE FROM reserves_out
+ WHERE reserve_uuid < reserve_uuid_min;
+
+-- FIXME: this query will be horribly slow;
+-- need to find another way to formulate it...
+DELETE FROM denominations
+ WHERE expire_legal < in_now
+ AND denominations_serial NOT IN
+ (SELECT DISTINCT denominations_serial
+ FROM reserves_out)
+ AND denominations_serial NOT IN
+ (SELECT DISTINCT denominations_serial
+ FROM known_coins
+ WHERE coin_pub IN
+ (SELECT DISTINCT coin_pub
+ FROM recoup))
+ AND denominations_serial NOT IN
+ (SELECT DISTINCT denominations_serial
+ FROM known_coins
+ WHERE coin_pub IN
+ (SELECT DISTINCT coin_pub
+ FROM recoup_refresh));
+
+SELECT
+ melt_serial_id
+ INTO
+ melt_min
+ FROM refresh_commitments
+ ORDER BY melt_serial_id ASC
+ LIMIT 1;
+
+DELETE FROM refresh_revealed_coins
+ WHERE melt_serial_id < melt_min;
+
+DELETE FROM refresh_transfer_keys
+ WHERE melt_serial_id < melt_min;
+
+SELECT
+ known_coin_id
+ INTO
+ coin_min
+ FROM known_coins
+ ORDER BY known_coin_id ASC
+ LIMIT 1;
+
+DELETE FROM deposits
+ WHERE known_coin_id < coin_min;
+
+SELECT
+ deposit_serial_id
+ INTO
+ deposit_min
+ FROM deposits
+ ORDER BY deposit_serial_id ASC
+ LIMIT 1;
+
+DELETE FROM refunds
+ WHERE deposit_serial_id < deposit_min;
+
+DELETE FROM aggregation_tracking
+ WHERE deposit_serial_id < deposit_min;
+
+SELECT
+ denominations_serial
+ INTO
+ denom_min
+ FROM denominations
+ ORDER BY denominations_serial ASC
+ LIMIT 1;
+
+DELETE FROM cs_nonce_locks
+ WHERE max_denomination_serial <= denom_min;
+
+END $$;
+
+
+--
+-- Name: exchange_do_history_request(bytea, bytea, bigint, bigint, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_history_request(in_reserve_pub bytea, in_reserve_sig bytea, in_request_timestamp bigint, in_history_fee_val bigint, in_history_fee_frac integer, OUT out_balance_ok boolean, OUT out_idempotent boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ -- Insert and check for idempotency.
+ INSERT INTO history_requests
+ (reserve_pub
+ ,request_timestamp
+ ,reserve_sig
+ ,history_fee_val
+ ,history_fee_frac)
+ VALUES
+ (in_reserve_pub
+ ,in_request_timestamp
+ ,in_reserve_sig
+ ,in_history_fee_val
+ ,in_history_fee_frac)
+ ON CONFLICT DO NOTHING;
+
+ IF NOT FOUND
+ THEN
+ out_balance_ok=TRUE;
+ out_idempotent=TRUE;
+ RETURN;
+ END IF;
+
+ out_idempotent=FALSE;
+
+ -- Update reserve balance.
+ UPDATE reserves
+ SET
+ current_balance_frac=current_balance_frac-in_history_fee_frac
+ + CASE
+ WHEN current_balance_frac < in_history_fee_frac
+ THEN 100000000
+ ELSE 0
+ END,
+ current_balance_val=current_balance_val-in_history_fee_val
+ - CASE
+ WHEN current_balance_frac < in_history_fee_frac
+ THEN 1
+ ELSE 0
+ END
+ WHERE
+ reserve_pub=in_reserve_pub
+ AND ( (current_balance_val > in_history_fee_val) OR
+ ( (current_balance_frac >= in_history_fee_frac) AND
+ (current_balance_val >= in_history_fee_val) ) );
+
+ IF NOT FOUND
+ THEN
+ -- Either reserve does not exist, or balance insufficient.
+ -- Both we treat the same here as balance insufficient.
+ out_balance_ok=FALSE;
+ RETURN;
+ END IF;
+
+ out_balance_ok=TRUE;
+END $$;
+
+
+--
+-- Name: exchange_do_melt(bytea, bigint, integer, bytea, bytea, bytea, bigint, integer, boolean); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_melt(in_cs_rms bytea, in_amount_with_fee_val bigint, in_amount_with_fee_frac integer, in_rc bytea, in_old_coin_pub bytea, in_old_coin_sig bytea, in_known_coin_id bigint, in_noreveal_index integer, in_zombie_required boolean, OUT out_balance_ok boolean, OUT out_zombie_bad boolean, OUT out_noreveal_index integer) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ denom_max INT8;
+BEGIN
+-- Shards: INSERT refresh_commitments (by rc)
+-- (rare:) SELECT refresh_commitments (by old_coin_pub) -- crosses shards!
+-- (rare:) SEELCT refresh_revealed_coins (by melt_serial_id)
+-- (rare:) PERFORM recoup_refresh (by rrc_serial) -- crosses shards!
+-- UPDATE known_coins (by coin_pub)
+
+INSERT INTO refresh_commitments
+ (rc
+ ,old_coin_pub
+ ,old_coin_sig
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ ,noreveal_index
+ )
+ VALUES
+ (in_rc
+ ,in_old_coin_pub
+ ,in_old_coin_sig
+ ,in_amount_with_fee_val
+ ,in_amount_with_fee_frac
+ ,in_noreveal_index)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: see if an identical record exists.
+ out_noreveal_index=-1;
+ SELECT
+ noreveal_index
+ INTO
+ out_noreveal_index
+ FROM refresh_commitments
+ WHERE rc=in_rc;
+ out_balance_ok=FOUND;
+ out_zombie_bad=FALSE; -- zombie is OK
+ RETURN;
+END IF;
+
+
+IF in_zombie_required
+THEN
+ -- Check if this coin was part of a refresh
+ -- operation that was subsequently involved
+ -- in a recoup operation. We begin by all
+ -- refresh operations our coin was involved
+ -- with, then find all associated reveal
+ -- operations, and then see if any of these
+ -- reveal operations was involved in a recoup.
+ PERFORM
+ FROM recoup_refresh
+ WHERE rrc_serial IN
+ (SELECT rrc_serial
+ FROM refresh_revealed_coins
+ WHERE melt_serial_id IN
+ (SELECT melt_serial_id
+ FROM refresh_commitments
+ WHERE old_coin_pub=in_old_coin_pub));
+ IF NOT FOUND
+ THEN
+ out_zombie_bad=TRUE;
+ out_balance_ok=FALSE;
+ RETURN;
+ END IF;
+END IF;
+
+out_zombie_bad=FALSE; -- zombie is OK
+
+
+-- Check and update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=remaining_frac-in_amount_with_fee_frac
+ + CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val-in_amount_with_fee_val
+ - CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub=in_old_coin_pub
+ AND ( (remaining_val > in_amount_with_fee_val) OR
+ ( (remaining_frac >= in_amount_with_fee_frac) AND
+ (remaining_val >= in_amount_with_fee_val) ) );
+
+IF NOT FOUND
+THEN
+ -- Insufficient balance.
+ out_noreveal_index=-1;
+ out_balance_ok=FALSE;
+ RETURN;
+END IF;
+
+
+
+-- Special actions needed for a CS melt?
+IF NOT NULL in_cs_rms
+THEN
+ -- Get maximum denominations serial value in
+ -- existence, this will determine how long the
+ -- nonce will be locked.
+ SELECT
+ denominations_serial
+ INTO
+ denom_max
+ FROM denominations
+ ORDER BY denominations_serial DESC
+ LIMIT 1;
+
+ -- Cache CS signature to prevent replays in the future
+ -- (and check if cached signature exists at the same time).
+ INSERT INTO cs_nonce_locks
+ (nonce
+ ,max_denomination_serial
+ ,op_hash)
+ VALUES
+ (cs_rms
+ ,denom_serial
+ ,in_rc)
+ ON CONFLICT DO NOTHING;
+
+ IF NOT FOUND
+ THEN
+ -- Record exists, make sure it is the same
+ SELECT 1
+ FROM cs_nonce_locks
+ WHERE nonce=cs_rms
+ AND op_hash=in_rc;
+
+ IF NOT FOUND
+ THEN
+ -- Nonce reuse detected
+ out_balance_ok=FALSE;
+ out_zombie_bad=FALSE;
+ out_noreveal_index=42; -- FIXME: return error message more nicely!
+ ASSERT false, 'nonce reuse attempted by client';
+ END IF;
+ END IF;
+END IF;
+
+-- Everything fine, return success!
+out_balance_ok=TRUE;
+out_noreveal_index=in_noreveal_index;
+
+END $$;
+
+
+--
+-- Name: exchange_do_purse_deposit(bigint, bytea, bigint, integer, bytea, bytea, bigint, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_purse_deposit(in_partner_id bigint, in_purse_pub bytea, in_amount_with_fee_val bigint, in_amount_with_fee_frac integer, in_coin_pub bytea, in_coin_sig bytea, in_amount_without_fee_val bigint, in_amount_without_fee_frac integer, OUT out_balance_ok boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ was_merged BOOLEAN;
+DECLARE
+ psi INT8; -- partner's serial ID (set if merged)
+DECLARE
+ my_amount_val INT8; -- total in purse
+DECLARE
+ my_amount_frac INT4; -- total in purse
+DECLARE
+ was_paid BOOLEAN;
+DECLARE
+ my_reserve_pub BYTEA;
+BEGIN
+
+-- Store the deposit request.
+INSERT INTO purse_deposits
+ (partner_serial_id
+ ,purse_pub
+ ,coin_pub
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ ,coin_sig)
+ VALUES
+ (in_partner_id
+ ,in_purse_pub
+ ,in_coin_pub
+ ,in_amount_with_fee_val
+ ,in_amount_with_fee_frac
+ ,in_coin_sig)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: check if coin_sig is the same,
+ -- if so, success, otherwise conflict!
+ PERFORM
+ FROM purse_deposits
+ WHERE coin_pub = in_coin_pub
+ AND purse_pub = in_purse_pub
+ AND coin_sig = in_cion_sig;
+ IF NOT FOUND
+ THEN
+ -- Deposit exists, but with differences. Not allowed.
+ out_balance_ok=FALSE;
+ out_conflict=TRUE;
+ RETURN;
+ END IF;
+END IF;
+
+
+-- Debit the coin
+-- Check and update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=remaining_frac-in_amount_with_fee_frac
+ + CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val-in_amount_with_fee_val
+ - CASE
+ WHEN remaining_frac < in_amount_with_fee_frac
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub=in_coin_pub
+ AND ( (remaining_val > in_amount_with_fee_val) OR
+ ( (remaining_frac >= in_amount_with_fee_frac) AND
+ (remaining_val >= in_amount_with_fee_val) ) );
+
+IF NOT FOUND
+THEN
+ -- Insufficient balance.
+ out_balance_ok=FALSE;
+ out_conflict=FALSE;
+ RETURN;
+END IF;
+
+
+-- Credit the purse.
+UPDATE purse_requests
+ SET
+ balance_frac=balance_frac+in_amount_without_fee_frac
+ - CASE
+ WHEN balance_frac+in_amount_without_fee_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ balance_val=balance_val+in_amount_without_fee_val
+ + CASE
+ WHEN balance_frac+in_amount_without_fee_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE purse_pub=in_purse_pub;
+
+out_conflict=FALSE;
+out_balance_ok=TRUE;
+
+-- See if we can finish the merge or need to update the trigger time and partner.
+SELECT partner_serial_id
+ ,reserve_pub
+ INTO psi
+ ,my_reserve_pub
+ FROM purse_merges
+ WHERE purse_pub=in_purse_pub;
+
+IF NOT FOUND
+THEN
+ RETURN;
+END IF;
+
+SELECT
+ amount_with_fee_val
+ ,amount_with_fee_frac
+ INTO
+ my_amount_val
+ ,my_amount_frac
+ FROM purse_requests
+ WHERE (purse_pub=in_purse_pub)
+ AND ( ( ( (amount_with_fee_val <= balance_val)
+ AND (amount_with_fee_frac <= balance_frac) )
+ OR (amount_with_fee_val < balance_val) ) );
+IF NOT FOUND
+THEN
+ RETURN;
+END IF;
+
+IF (0 != psi)
+THEN
+ -- The taler-exchange-router will take care of this.
+ UPDATE purse_actions
+ SET action_date=0 --- "immediately"
+ ,partner_serial_id=psi
+ WHERE purse_pub=in_purse_pub;
+ELSE
+ -- This is a local reserve, update balance immediately.
+ UPDATE reserves
+ SET
+ current_balance_frac=current_balance_frac+my_amount_frac
+ - CASE
+ WHEN current_balance_frac + my_amount_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ current_balance_val=current_balance_val+my_amount_val
+ + CASE
+ WHEN current_balance_frac + my_amount_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE reserve_pub=my_reserve_pub;
+
+ -- ... and mark purse as finished.
+ -- FIXME: combine with UPDATE above?
+ UPDATE purse_requests
+ SET finished=true
+ WHERE purse_pub=in_purse_pub;
+END IF;
+
+
+END $$;
+
+
+--
+-- Name: exchange_do_purse_merge(bytea, bytea, bigint, bytea, character varying, bytea, boolean); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_purse_merge(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_partner_url character varying, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_partner boolean, OUT out_no_balance boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ my_amount_val INT8;
+DECLARE
+ my_amount_frac INT4;
+DECLARE
+ my_purse_fee_val INT8;
+DECLARE
+ my_purse_fee_frac INT4;
+DECLARE
+ my_partner_serial_id INT8;
+DECLARE
+ my_finished BOOLEAN;
+BEGIN
+
+IF in_partner_url IS NULL
+THEN
+ my_partner_serial_id=0;
+ELSE
+ SELECT
+ partner_serial_id
+ INTO
+ my_partner_serial_id
+ FROM partners
+ WHERE partner_base_url=in_partner_url
+ AND start_date <= in_merge_timestamp
+ AND end_date > in_merge_timestamp;
+ IF NOT FOUND
+ THEN
+ out_no_partner=TRUE;
+ out_conflict=FALSE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ RETURN;
+ END IF;
+END IF;
+
+out_no_partner=FALSE;
+
+
+-- Check purse is 'full'.
+SELECT amount_with_fee_val
+ ,amount_with_fee_frac
+ ,purse_fee_val
+ ,purse_fee_frac
+ ,finished
+ INTO my_amount_val
+ ,my_amount_frac
+ ,my_purse_fee_val
+ ,my_purse_fee_frac
+ ,my_finished
+ FROM purse_requests
+ WHERE purse_pub=in_purse_pub
+ AND balance_val >= amount_with_fee_val
+ AND ( (balance_frac >= amount_with_fee_frac) OR
+ (balance_val > amount_with_fee_val) );
+IF NOT FOUND
+THEN
+ out_no_balance=TRUE;
+ out_conflict=FALSE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ RETURN;
+END IF;
+out_no_balance=FALSE;
+
+-- Store purse merge signature, checks for purse_pub uniqueness
+INSERT INTO purse_merges
+ (partner_serial_id
+ ,reserve_pub
+ ,purse_pub
+ ,merge_sig
+ ,merge_timestamp)
+ VALUES
+ (my_partner_serial_id
+ ,in_reserve_pub
+ ,in_purse_pub
+ ,in_merge_sig
+ ,in_merge_timestamp)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: see if an identical record exists.
+ -- Note that by checking 'merge_sig', we implicitly check
+ -- identity over everything that the signature covers.
+ PERFORM
+ FROM purse_merges
+ WHERE purse_pub=in_purse_pub
+ AND merge_sig=in_merge_sig;
+ IF NOT FOUND
+ THEN
+ -- Purse was merged, but to some other reserve. Not allowed.
+ out_conflict=TRUE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ RETURN;
+ END IF;
+
+ -- "success"
+ out_conflict=FALSE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ RETURN;
+END IF;
+out_conflict=FALSE;
+
+ASSERT NOT my_finished, 'internal invariant failed';
+
+IF ( (in_partner_url IS NULL) AND
+ (in_require_kyc) )
+THEN
+ -- Need to do KYC check.
+ SELECT NOT kyc_passed
+ INTO out_no_kyc
+ FROM reserves
+ WHERE reserve_pub=in_reserve_pub;
+
+ IF NOT FOUND
+ THEN
+ out_no_kyc=TRUE;
+ out_no_reserve=TRUE;
+ RETURN;
+ END IF;
+ out_no_reserve=FALSE;
+
+ IF (out_no_kyc)
+ THEN
+ RETURN;
+ END IF;
+ELSE
+ -- KYC is not our responsibility
+ out_no_reserve=FALSE;
+ out_no_kyc=FALSE;
+END IF;
+
+
+
+-- Store account merge signature.
+INSERT INTO account_merges
+ (reserve_pub
+ ,reserve_sig
+ ,purse_pub)
+ VALUES
+ (in_reserve_pub
+ ,in_reserve_sig
+ ,in_purse_pub);
+
+-- If we need a wad transfer, mark purse ready for it.
+IF (0 != my_partner_serial_id)
+THEN
+ -- The taler-exchange-router will take care of this.
+ UPDATE purse_actions
+ SET action_date=0 --- "immediately"
+ ,partner_serial_id=my_partner_serial_id
+ WHERE purse_pub=in_purse_pub;
+ELSE
+ -- This is a local reserve, update reserve balance immediately.
+
+ -- Refund the purse fee, by adding it to the purse value:
+ my_amount_val = my_amount_val + my_purse_fee_val;
+ my_amount_frac = my_amount_frac + my_purse_fee_frac;
+ -- normalize result
+ my_amount_val = my_amount_val + my_amount_frac / 100000000;
+ my_amount_frac = my_amount_frac % 100000000;
+
+ UPDATE reserves
+ SET
+ current_balance_frac=current_balance_frac+my_amount_frac
+ - CASE
+ WHEN current_balance_frac + my_amount_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ current_balance_val=current_balance_val+my_amount_val
+ + CASE
+ WHEN current_balance_frac + my_amount_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE reserve_pub=in_reserve_pub;
+
+ -- ... and mark purse as finished.
+ UPDATE purse_requests
+ SET finished=true
+ WHERE purse_pub=in_purse_pub;
+END IF;
+
+
+RETURN;
+
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_purse_merge(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_partner_url character varying, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_partner boolean, OUT out_no_balance boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_purse_merge(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_partner_url character varying, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_partner boolean, OUT out_no_balance boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean) IS 'Checks that the partner exists, the purse has not been merged with a different reserve and that the purse is full. If so, persists the merge data and either merges the purse with the reserve or marks it as ready for the taler-exchange-router. Caller MUST abort the transaction on failures so as to not persist data by accident.';
+
+
+--
+-- Name: exchange_do_recoup_by_reserve(bytea); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_recoup_by_reserve(res_pub bytea) RETURNS TABLE(denom_sig bytea, denominations_serial bigint, coin_pub bytea, coin_sig bytea, coin_blind bytea, amount_val bigint, amount_frac integer, recoup_timestamp bigint)
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ res_uuid BIGINT;
+ blind_ev BYTEA;
+ c_pub BYTEA;
+BEGIN
+ SELECT reserve_uuid
+ INTO res_uuid
+ FROM reserves
+ WHERE reserves.reserve_pub = res_pub;
+
+ FOR blind_ev IN
+ SELECT h_blind_ev
+ FROM reserves_out_by_reserve
+ WHERE reserves_out_by_reserve.reserve_uuid = res_uuid
+ LOOP
+ SELECT robr.coin_pub
+ INTO c_pub
+ FROM recoup_by_reserve robr
+ WHERE robr.reserve_out_serial_id = (
+ SELECT reserves_out.reserve_out_serial_id
+ FROM reserves_out
+ WHERE reserves_out.h_blind_ev = blind_ev
+ );
+ RETURN QUERY
+ SELECT kc.denom_sig,
+ kc.denominations_serial,
+ rc.coin_pub,
+ rc.coin_sig,
+ rc.coin_blind,
+ rc.amount_val,
+ rc.amount_frac,
+ rc.recoup_timestamp
+ FROM (
+ SELECT *
+ FROM known_coins
+ WHERE known_coins.coin_pub = c_pub
+ ) kc
+ JOIN (
+ SELECT *
+ FROM recoup
+ WHERE recoup.coin_pub = c_pub
+ ) rc USING (coin_pub);
+ END LOOP;
+END;
+$$;
+
+
+--
+-- Name: FUNCTION exchange_do_recoup_by_reserve(res_pub bytea); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_recoup_by_reserve(res_pub bytea) IS 'Recoup by reserve as a function to make sure we hit only the needed partition and not all when joining as joins on distributed tables fetch ALL rows from the shards';
+
+
+--
+-- Name: exchange_do_recoup_to_coin(bytea, bigint, bytea, bytea, bigint, bytea, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_recoup_to_coin(in_old_coin_pub bytea, in_rrc_serial bigint, in_coin_blind bytea, in_coin_pub bytea, in_known_coin_id bigint, in_coin_sig bytea, in_recoup_timestamp bigint, OUT out_recoup_ok boolean, OUT out_internal_failure boolean, OUT out_recoup_timestamp bigint) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ tmp_val INT8; -- amount recouped
+DECLARE
+ tmp_frac INT8; -- amount recouped
+BEGIN
+
+-- Shards: UPDATE known_coins (by coin_pub)
+-- SELECT recoup_refresh (by coin_pub)
+-- UPDATE known_coins (by coin_pub)
+-- INSERT recoup_refresh (by coin_pub)
+
+
+out_internal_failure=FALSE;
+
+
+-- Check remaining balance of the coin.
+SELECT
+ remaining_frac
+ ,remaining_val
+ INTO
+ tmp_frac
+ ,tmp_val
+FROM known_coins
+ WHERE coin_pub=in_coin_pub;
+
+IF NOT FOUND
+THEN
+ out_internal_failure=TRUE;
+ out_recoup_ok=FALSE;
+ RETURN;
+END IF;
+
+IF tmp_val + tmp_frac = 0
+THEN
+ -- Check for idempotency
+ SELECT
+ recoup_timestamp
+ INTO
+ out_recoup_timestamp
+ FROM recoup_refresh
+ WHERE coin_pub=in_coin_pub;
+ out_recoup_ok=FOUND;
+ RETURN;
+END IF;
+
+-- Update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=0
+ ,remaining_val=0
+ WHERE coin_pub=in_coin_pub;
+
+
+-- Credit the old coin.
+UPDATE known_coins
+ SET
+ remaining_frac=remaining_frac+tmp_frac
+ - CASE
+ WHEN remaining_frac+tmp_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val+tmp_val
+ + CASE
+ WHEN remaining_frac+tmp_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub=in_old_coin_pub;
+
+
+IF NOT FOUND
+THEN
+ RAISE NOTICE 'failed to increase old coin balance from recoup';
+ out_recoup_ok=TRUE;
+ out_internal_failure=TRUE;
+ RETURN;
+END IF;
+
+
+INSERT INTO recoup_refresh
+ (coin_pub
+ ,known_coin_id
+ ,coin_sig
+ ,coin_blind
+ ,amount_val
+ ,amount_frac
+ ,recoup_timestamp
+ ,rrc_serial
+ )
+VALUES
+ (in_coin_pub
+ ,in_known_coin_id
+ ,in_coin_sig
+ ,in_coin_blind
+ ,tmp_val
+ ,tmp_frac
+ ,in_recoup_timestamp
+ ,in_rrc_serial);
+
+-- Normal end, everything is fine.
+out_recoup_ok=TRUE;
+out_recoup_timestamp=in_recoup_timestamp;
+
+END $$;
+
+
+--
+-- Name: exchange_do_recoup_to_reserve(bytea, bigint, bytea, bytea, bigint, bytea, bigint, bigint, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_recoup_to_reserve(in_reserve_pub bytea, in_reserve_out_serial_id bigint, in_coin_blind bytea, in_coin_pub bytea, in_known_coin_id bigint, in_coin_sig bytea, in_reserve_gc bigint, in_reserve_expiration bigint, in_recoup_timestamp bigint, OUT out_recoup_ok boolean, OUT out_internal_failure boolean, OUT out_recoup_timestamp bigint) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ tmp_val INT8; -- amount recouped
+DECLARE
+ tmp_frac INT8; -- amount recouped
+BEGIN
+-- Shards: SELECT known_coins (by coin_pub)
+-- SELECT recoup (by coin_pub)
+-- UPDATE known_coins (by coin_pub)
+-- UPDATE reserves (by reserve_pub)
+-- INSERT recoup (by coin_pub)
+
+out_internal_failure=FALSE;
+
+
+-- Check remaining balance of the coin.
+SELECT
+ remaining_frac
+ ,remaining_val
+ INTO
+ tmp_frac
+ ,tmp_val
+FROM known_coins
+ WHERE coin_pub=in_coin_pub;
+
+IF NOT FOUND
+THEN
+ out_internal_failure=TRUE;
+ out_recoup_ok=FALSE;
+ RETURN;
+END IF;
+
+IF tmp_val + tmp_frac = 0
+THEN
+ -- Check for idempotency
+ SELECT
+ recoup_timestamp
+ INTO
+ out_recoup_timestamp
+ FROM recoup
+ WHERE coin_pub=in_coin_pub;
+
+ out_recoup_ok=FOUND;
+ RETURN;
+END IF;
+
+
+-- Update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=0
+ ,remaining_val=0
+ WHERE coin_pub=in_coin_pub;
+
+
+-- Credit the reserve and update reserve timers.
+UPDATE reserves
+ SET
+ current_balance_frac=current_balance_frac+tmp_frac
+ - CASE
+ WHEN current_balance_frac+tmp_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ current_balance_val=current_balance_val+tmp_val
+ + CASE
+ WHEN current_balance_frac+tmp_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END,
+ gc_date=GREATEST(gc_date, in_reserve_gc),
+ expiration_date=GREATEST(expiration_date, in_reserve_expiration)
+ WHERE reserve_pub=in_reserve_pub;
+
+
+IF NOT FOUND
+THEN
+ RAISE NOTICE 'failed to increase reserve balance from recoup';
+ out_recoup_ok=TRUE;
+ out_internal_failure=TRUE;
+ RETURN;
+END IF;
+
+
+INSERT INTO recoup
+ (coin_pub
+ ,coin_sig
+ ,coin_blind
+ ,amount_val
+ ,amount_frac
+ ,recoup_timestamp
+ ,reserve_out_serial_id
+ )
+VALUES
+ (in_coin_pub
+ ,in_coin_sig
+ ,in_coin_blind
+ ,tmp_val
+ ,tmp_frac
+ ,in_recoup_timestamp
+ ,in_reserve_out_serial_id);
+
+-- Normal end, everything is fine.
+out_recoup_ok=TRUE;
+out_recoup_timestamp=in_recoup_timestamp;
+
+END $$;
+
+
+--
+-- Name: exchange_do_refund(bigint, integer, bigint, integer, bigint, integer, bytea, bigint, bigint, bigint, bytea, bytea, bytea); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_refund(in_amount_with_fee_val bigint, in_amount_with_fee_frac integer, in_amount_val bigint, in_amount_frac integer, in_deposit_fee_val bigint, in_deposit_fee_frac integer, in_h_contract_terms bytea, in_rtransaction_id bigint, in_deposit_shard bigint, in_known_coin_id bigint, in_coin_pub bytea, in_merchant_pub bytea, in_merchant_sig bytea, OUT out_not_found boolean, OUT out_refund_ok boolean, OUT out_gone boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ dsi INT8; -- ID of deposit being refunded
+DECLARE
+ tmp_val INT8; -- total amount refunded
+DECLARE
+ tmp_frac INT8; -- total amount refunded
+DECLARE
+ deposit_val INT8; -- amount that was originally deposited
+DECLARE
+ deposit_frac INT8; -- amount that was originally deposited
+BEGIN
+-- Shards: SELECT deposits (coin_pub, shard, h_contract_terms, merchant_pub)
+-- INSERT refunds (by coin_pub, rtransaction_id) ON CONFLICT DO NOTHING
+-- SELECT refunds (by coin_pub)
+-- UPDATE known_coins (by coin_pub)
+
+SELECT
+ deposit_serial_id
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ ,done
+INTO
+ dsi
+ ,deposit_val
+ ,deposit_frac
+ ,out_gone
+FROM deposits
+ WHERE coin_pub=in_coin_pub
+ AND shard=in_deposit_shard
+ AND merchant_pub=in_merchant_pub
+ AND h_contract_terms=in_h_contract_terms;
+
+IF NOT FOUND
+THEN
+ -- No matching deposit found!
+ out_refund_ok=FALSE;
+ out_conflict=FALSE;
+ out_not_found=TRUE;
+ out_gone=FALSE;
+ RETURN;
+END IF;
+
+INSERT INTO refunds
+ (deposit_serial_id
+ ,coin_pub
+ ,merchant_sig
+ ,rtransaction_id
+ ,amount_with_fee_val
+ ,amount_with_fee_frac
+ )
+ VALUES
+ (dsi
+ ,in_coin_pub
+ ,in_merchant_sig
+ ,in_rtransaction_id
+ ,in_amount_with_fee_val
+ ,in_amount_with_fee_frac)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: see if an identical record exists.
+ -- Note that by checking 'coin_sig', we implicitly check
+ -- identity over everything that the signature covers.
+ -- We do select over merchant_pub and h_contract_terms
+ -- primarily here to maximally use the existing index.
+ PERFORM
+ FROM refunds
+ WHERE coin_pub=in_coin_pub
+ AND deposit_serial_id=dsi
+ AND rtransaction_id=in_rtransaction_id
+ AND amount_with_fee_val=in_amount_with_fee_val
+ AND amount_with_fee_frac=in_amount_with_fee_frac;
+
+ IF NOT FOUND
+ THEN
+ -- Deposit exists, but have conflicting refund.
+ out_refund_ok=FALSE;
+ out_conflict=TRUE;
+ out_not_found=FALSE;
+ RETURN;
+ END IF;
+
+ -- Idempotent request known, return success.
+ out_refund_ok=TRUE;
+ out_conflict=FALSE;
+ out_not_found=FALSE;
+ out_gone=FALSE;
+ RETURN;
+END IF;
+
+IF out_gone
+THEN
+ -- money already sent to the merchant. Tough luck.
+ out_refund_ok=FALSE;
+ out_conflict=FALSE;
+ out_not_found=FALSE;
+ RETURN;
+END IF;
+
+-- Check refund balance invariant.
+SELECT
+ SUM(amount_with_fee_val) -- overflow here is not plausible
+ ,SUM(CAST(amount_with_fee_frac AS INT8)) -- compute using 64 bits
+ INTO
+ tmp_val
+ ,tmp_frac
+ FROM refunds
+ WHERE coin_pub=in_coin_pub
+ AND deposit_serial_id=dsi;
+IF tmp_val IS NULL
+THEN
+ RAISE NOTICE 'failed to sum up existing refunds';
+ out_refund_ok=FALSE;
+ out_conflict=FALSE;
+ out_not_found=FALSE;
+ RETURN;
+END IF;
+
+-- Normalize result before continuing
+tmp_val = tmp_val + tmp_frac / 100000000;
+tmp_frac = tmp_frac % 100000000;
+
+-- Actually check if the deposits are sufficient for the refund. Verbosely. ;-)
+IF (tmp_val < deposit_val)
+THEN
+ out_refund_ok=TRUE;
+ELSE
+ IF (tmp_val = deposit_val) AND (tmp_frac <= deposit_frac)
+ THEN
+ out_refund_ok=TRUE;
+ ELSE
+ out_refund_ok=FALSE;
+ END IF;
+END IF;
+
+IF (tmp_val = deposit_val) AND (tmp_frac = deposit_frac)
+THEN
+ -- Refunds have reached the full value of the original
+ -- deposit. Also refund the deposit fee.
+ in_amount_frac = in_amount_frac + in_deposit_fee_frac;
+ in_amount_val = in_amount_val + in_deposit_fee_val;
+
+ -- Normalize result before continuing
+ in_amount_val = in_amount_val + in_amount_frac / 100000000;
+ in_amount_frac = in_amount_frac % 100000000;
+END IF;
+
+-- Update balance of the coin.
+UPDATE known_coins
+ SET
+ remaining_frac=remaining_frac+in_amount_frac
+ - CASE
+ WHEN remaining_frac+in_amount_frac >= 100000000
+ THEN 100000000
+ ELSE 0
+ END,
+ remaining_val=remaining_val+in_amount_val
+ + CASE
+ WHEN remaining_frac+in_amount_frac >= 100000000
+ THEN 1
+ ELSE 0
+ END
+ WHERE coin_pub=in_coin_pub;
+
+
+out_conflict=FALSE;
+out_not_found=FALSE;
+
+END $$;
+
+
+--
+-- Name: exchange_do_reserve_purse(bytea, bytea, bigint, bytea, boolean, bigint, integer, bytea, boolean); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_reserve_purse(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_reserve_quota boolean, in_purse_fee_val bigint, in_purse_fee_frac integer, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_funds boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+-- Store purse merge signature, checks for purse_pub uniqueness
+INSERT INTO purse_merges
+ (partner_serial_id
+ ,reserve_pub
+ ,purse_pub
+ ,merge_sig
+ ,merge_timestamp)
+ VALUES
+ (0
+ ,in_reserve_pub
+ ,in_purse_pub
+ ,in_merge_sig
+ ,in_merge_timestamp)
+ ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- Idempotency check: see if an identical record exists.
+ -- Note that by checking 'merge_sig', we implicitly check
+ -- identity over everything that the signature covers.
+ PERFORM
+ FROM purse_merges
+ WHERE purse_pub=in_purse_pub
+ AND merge_sig=in_merge_sig;
+ IF NOT FOUND
+ THEN
+ -- Purse was merged, but to some other reserve. Not allowed.
+ out_conflict=TRUE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ out_no_funds=FALSE;
+ RETURN;
+ END IF;
+
+ -- "success"
+ out_conflict=FALSE;
+ out_no_funds=FALSE;
+ out_no_kyc=FALSE;
+ out_no_reserve=FALSE;
+ RETURN;
+END IF;
+out_conflict=FALSE;
+
+SELECT NOT kyc_passed
+ INTO out_no_kyc
+ FROM reserves
+ WHERE reserve_pub=in_reserve_pub;
+
+IF NOT FOUND
+THEN
+ out_no_kyc=TRUE;
+ out_no_reserve=TRUE;
+ out_no_funds=TRUE;
+ RETURN;
+END IF;
+out_no_reserve=FALSE;
+
+IF (out_no_kyc AND in_require_kyc)
+THEN
+ out_no_funds=FALSE;
+ RETURN;
+END IF;
+
+IF (in_reserve_quota)
+THEN
+ -- Increment active purses per reserve (and check this is allowed)
+ UPDATE reserves
+ SET purses_active=purses_active+1
+ ,kyc_required=TRUE
+ WHERE reserve_pub=in_reserve_pub
+ AND purses_active < purses_allowed;
+ IF NOT FOUND
+ THEN
+ out_no_funds=TRUE;
+ RETURN;
+ END IF;
+ELSE
+ -- UPDATE reserves balance (and check if balance is enough to pay the fee)
+ UPDATE reserves
+ SET
+ current_balance_frac=current_balance_frac-in_purse_fee_frac
+ + CASE
+ WHEN current_balance_frac < in_purse_fee_frac
+ THEN 100000000
+ ELSE 0
+ END,
+ current_balance_val=current_balance_val-in_purse_fee_val
+ - CASE
+ WHEN current_balance_frac < in_purse_fee_frac
+ THEN 1
+ ELSE 0
+ END
+ ,kyc_required=TRUE
+ WHERE reserve_pub=in_reserve_pub
+ AND ( (current_balance_val > in_purse_fee_val) OR
+ ( (current_balance_frac >= in_purse_fee_frac) AND
+ (current_balance_val >= in_purse_fee_val) ) );
+ IF NOT FOUND
+ THEN
+ out_no_funds=TRUE;
+ RETURN;
+ END IF;
+END IF;
+
+out_no_funds=FALSE;
+
+
+-- Store account merge signature.
+INSERT INTO account_merges
+ (reserve_pub
+ ,reserve_sig
+ ,purse_pub)
+ VALUES
+ (in_reserve_pub
+ ,in_reserve_sig
+ ,in_purse_pub);
+
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_reserve_purse(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_reserve_quota boolean, in_purse_fee_val bigint, in_purse_fee_frac integer, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_funds boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_reserve_purse(in_purse_pub bytea, in_merge_sig bytea, in_merge_timestamp bigint, in_reserve_sig bytea, in_reserve_quota boolean, in_purse_fee_val bigint, in_purse_fee_frac integer, in_reserve_pub bytea, in_require_kyc boolean, OUT out_no_funds boolean, OUT out_no_kyc boolean, OUT out_no_reserve boolean, OUT out_conflict boolean) IS 'Create a purse for a reserve.';
+
+
+--
+-- Name: exchange_do_withdraw(bytea, bigint, integer, bytea, bytea, bytea, bytea, bytea, bigint, bigint); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_withdraw(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, rpub bytea, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint) RETURNS record
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ reserve_gc INT8;
+DECLARE
+ denom_serial INT8;
+DECLARE
+ reserve_val INT8;
+DECLARE
+ reserve_frac INT4;
+BEGIN
+-- Shards: reserves by reserve_pub (SELECT)
+-- reserves_out (INSERT, with CONFLICT detection) by wih
+-- reserves by reserve_pub (UPDATE)
+-- reserves_in by reserve_pub (SELECT)
+-- wire_targets by wire_target_h_payto
+
+SELECT denominations_serial
+ INTO denom_serial
+ FROM denominations
+ WHERE denom_pub_hash=h_denom_pub;
+
+IF NOT FOUND
+THEN
+ -- denomination unknown, should be impossible!
+ reserve_found=FALSE;
+ balance_ok=FALSE;
+ kycok=FALSE;
+ account_uuid=0;
+ ruuid=0;
+ ASSERT false, 'denomination unknown';
+ RETURN;
+END IF;
+
+
+SELECT
+ current_balance_val
+ ,current_balance_frac
+ ,gc_date
+ ,reserve_uuid
+ INTO
+ reserve_val
+ ,reserve_frac
+ ,reserve_gc
+ ,ruuid
+ FROM reserves
+ WHERE reserves.reserve_pub=rpub;
+
+IF NOT FOUND
+THEN
+ -- reserve unknown
+ reserve_found=FALSE;
+ balance_ok=FALSE;
+ kycok=FALSE;
+ account_uuid=0;
+ ruuid=2;
+ RETURN;
+END IF;
+
+-- We optimistically insert, and then on conflict declare
+-- the query successful due to idempotency.
+INSERT INTO reserves_out
+ (h_blind_ev
+ ,denominations_serial
+ ,denom_sig
+ ,reserve_uuid
+ ,reserve_sig
+ ,execution_date
+ ,amount_with_fee_val
+ ,amount_with_fee_frac)
+VALUES
+ (h_coin_envelope
+ ,denom_serial
+ ,denom_sig
+ ,ruuid
+ ,reserve_sig
+ ,now
+ ,amount_val
+ ,amount_frac)
+ON CONFLICT DO NOTHING;
+
+IF NOT FOUND
+THEN
+ -- idempotent query, all constraints must be satisfied
+ reserve_found=TRUE;
+ balance_ok=TRUE;
+ kycok=TRUE;
+ account_uuid=0;
+ RETURN;
+END IF;
+
+-- Check reserve balance is sufficient.
+IF (reserve_val > amount_val)
+THEN
+ IF (reserve_frac >= amount_frac)
+ THEN
+ reserve_val=reserve_val - amount_val;
+ reserve_frac=reserve_frac - amount_frac;
+ ELSE
+ reserve_val=reserve_val - amount_val - 1;
+ reserve_frac=reserve_frac + 100000000 - amount_frac;
+ END IF;
+ELSE
+ IF (reserve_val = amount_val) AND (reserve_frac >= amount_frac)
+ THEN
+ reserve_val=0;
+ reserve_frac=reserve_frac - amount_frac;
+ ELSE
+ reserve_found=TRUE;
+ balance_ok=FALSE;
+ kycok=FALSE; -- we do not really know or care
+ account_uuid=0;
+ RETURN;
+ END IF;
+END IF;
+
+-- Calculate new expiration dates.
+min_reserve_gc=GREATEST(min_reserve_gc,reserve_gc);
+
+-- Update reserve balance.
+UPDATE reserves SET
+ gc_date=min_reserve_gc
+ ,current_balance_val=reserve_val
+ ,current_balance_frac=reserve_frac
+WHERE
+ reserves.reserve_pub=rpub;
+
+reserve_found=TRUE;
+balance_ok=TRUE;
+
+
+
+-- Special actions needed for a CS withdraw?
+IF NOT NULL cs_nonce
+THEN
+ -- Cache CS signature to prevent replays in the future
+ -- (and check if cached signature exists at the same time).
+ INSERT INTO cs_nonce_locks
+ (nonce
+ ,max_denomination_serial
+ ,op_hash)
+ VALUES
+ (cs_nonce
+ ,denom_serial
+ ,h_coin_envelope)
+ ON CONFLICT DO NOTHING;
+
+ IF NOT FOUND
+ THEN
+ -- See if the existing entry is identical.
+ SELECT 1
+ FROM cs_nonce_locks
+ WHERE nonce=cs_nonce
+ AND op_hash=h_coin_envelope;
+ IF NOT FOUND
+ THEN
+ reserve_found=FALSE;
+ balance_ok=FALSE;
+ kycok=FALSE;
+ account_uuid=0;
+ ruuid=1; -- FIXME: return error message more nicely!
+ ASSERT false, 'nonce reuse attempted by client';
+ END IF;
+ END IF;
+END IF;
+
+
+
+-- Obtain KYC status based on the last wire transfer into
+-- this reserve. FIXME: likely not adequate for reserves that got P2P transfers!
+-- SELECT
+-- kyc_ok
+-- ,wire_target_serial_id
+-- INTO
+-- kycok
+-- ,account_uuid
+-- FROM reserves_in
+-- JOIN wire_targets ON (wire_source_h_payto = wire_target_h_payto)
+-- WHERE reserve_pub=rpub
+-- LIMIT 1; -- limit 1 should not be required (without p2p transfers)
+
+WITH reserves_in AS materialized (
+ SELECT wire_source_h_payto
+ FROM reserves_in WHERE
+ reserve_pub=rpub
+)
+SELECT
+ kyc_ok
+ ,wire_target_serial_id
+INTO
+ kycok
+ ,account_uuid
+FROM wire_targets
+ WHERE wire_target_h_payto = (
+ SELECT wire_source_h_payto
+ FROM reserves_in
+ );
+
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_withdraw(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, rpub bytea, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_withdraw(cs_nonce bytea, amount_val bigint, amount_frac integer, h_denom_pub bytea, rpub bytea, reserve_sig bytea, h_coin_envelope bytea, denom_sig bytea, now bigint, min_reserve_gc bigint, OUT reserve_found boolean, OUT balance_ok boolean, OUT kycok boolean, OUT account_uuid bigint, OUT ruuid bigint) IS 'Checks whether the reserve has sufficient balance for a withdraw operation (or the request is repeated and was previously approved) and if so updates the database with the result';
+
+
+--
+-- Name: exchange_do_withdraw_limit_check(bigint, bigint, bigint, integer); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.exchange_do_withdraw_limit_check(ruuid bigint, start_time bigint, upper_limit_val bigint, upper_limit_frac integer, OUT below_limit boolean) RETURNS boolean
+ LANGUAGE plpgsql
+ AS $$
+DECLARE
+ total_val INT8;
+DECLARE
+ total_frac INT8; -- INT4 could overflow during accumulation!
+BEGIN
+-- NOTE: Read-only, but crosses shards.
+-- Shards: reserves by reserve_pub
+-- reserves_out by reserve_uuid -- crosses shards!!
+
+
+SELECT
+ SUM(amount_with_fee_val) -- overflow here is not plausible
+ ,SUM(CAST(amount_with_fee_frac AS INT8)) -- compute using 64 bits
+ INTO
+ total_val
+ ,total_frac
+ FROM reserves_out
+ WHERE reserve_uuid=ruuid
+ AND execution_date > start_time;
+
+-- normalize result
+total_val = total_val + total_frac / 100000000;
+total_frac = total_frac % 100000000;
+
+-- compare to threshold
+below_limit = (total_val < upper_limit_val) OR
+ ( (total_val = upper_limit_val) AND
+ (total_frac <= upper_limit_frac) );
+END $$;
+
+
+--
+-- Name: FUNCTION exchange_do_withdraw_limit_check(ruuid bigint, start_time bigint, upper_limit_val bigint, upper_limit_frac integer, OUT below_limit boolean); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.exchange_do_withdraw_limit_check(ruuid bigint, start_time bigint, upper_limit_val bigint, upper_limit_frac integer, OUT below_limit boolean) IS 'Check whether the withdrawals from the given reserve since the given time are below the given threshold';
+
+
+--
+-- Name: prepare_sharding(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.prepare_sharding() RETURNS void
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+
+ CREATE EXTENSION IF NOT EXISTS postgres_fdw;
+
+ PERFORM detach_default_partitions();
+
+ ALTER TABLE IF EXISTS wire_targets
+ DROP CONSTRAINT IF EXISTS wire_targets_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS reserves
+ DROP CONSTRAINT IF EXISTS reserves_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS reserves_in
+ DROP CONSTRAINT IF EXISTS reserves_in_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS reserves_close
+ DROP CONSTRAINT IF EXISTS reserves_close_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS reserves_out
+ DROP CONSTRAINT IF EXISTS reserves_out_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS reserves_out_denominations_serial_fkey
+ ,DROP CONSTRAINT IF EXISTS reserves_out_h_blind_ev_key
+ ;
+
+ ALTER TABLE IF EXISTS known_coins
+ DROP CONSTRAINT IF EXISTS known_coins_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS known_coins_denominations_serial_fkey
+ ;
+
+ ALTER TABLE IF EXISTS refresh_commitments
+ DROP CONSTRAINT IF EXISTS refresh_commitments_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS refresh_old_coin_pub_fkey
+ ;
+
+ ALTER TABLE IF EXISTS refresh_revealed_coins
+ DROP CONSTRAINT IF EXISTS refresh_revealed_coins_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS refresh_revealed_coins_denominations_serial_fkey
+ ;
+
+ ALTER TABLE IF EXISTS refresh_transfer_keys
+ DROP CONSTRAINT IF EXISTS refresh_transfer_keys_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS deposits
+ DROP CONSTRAINT IF EXISTS deposits_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS deposits_extension_details_serial_id_fkey
+ ,DROP CONSTRAINT IF EXISTS deposits_coin_pub_merchant_pub_h_contract_terms_key CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS refunds
+ DROP CONSTRAINT IF EXISTS refunds_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS wire_out
+ DROP CONSTRAINT IF EXISTS wire_out_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS wire_out_wtid_raw_key CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS aggregation_tracking
+ DROP CONSTRAINT IF EXISTS aggregation_tracking_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS aggregation_tracking_wtid_raw_fkey
+ ;
+
+ ALTER TABLE IF EXISTS recoup
+ DROP CONSTRAINT IF EXISTS recoup_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS recoup_refresh
+ DROP CONSTRAINT IF EXISTS recoup_refresh_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS prewire
+ DROP CONSTRAINT IF EXISTS prewire_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS cs_nonce_locks
+ DROP CONSTRAINT IF EXISTS cs_nonce_locks_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS purse_requests
+ DROP CONSTRAINT IF EXISTS purse_requests_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS purse_refunds
+ DROP CONSTRAINT IF EXISTS purse_refunds_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS purse_merges
+ DROP CONSTRAINT IF EXISTS purse_merges_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS account_merges
+ DROP CONSTRAINT IF EXISTS account_merges_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS contracts
+ DROP CONSTRAINT IF EXISTS contracts_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS history_requests
+ DROP CONSTRAINT IF EXISTS history_requests_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS close_requests
+ DROP CONSTRAINT IF EXISTS close_requests_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS purse_deposits
+ DROP CONSTRAINT IF EXISTS purse_deposits_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS wads_out
+ DROP CONSTRAINT IF EXISTS wads_out_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS wad_out_entries
+ DROP CONSTRAINT IF EXISTS wad_out_entries_pkey CASCADE
+ ;
+
+ ALTER TABLE IF EXISTS wads_in
+ DROP CONSTRAINT IF EXISTS wads_in_pkey CASCADE
+ ,DROP CONSTRAINT IF EXISTS wads_in_wad_id_origin_exchange_url_key
+ ;
+
+ ALTER TABLE IF EXISTS wad_in_entries
+ DROP CONSTRAINT IF EXISTS wad_in_entries_pkey CASCADE
+ ;
+
+END
+$$;
+
+
+--
+-- Name: purse_requests_insert_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.purse_requests_insert_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ ASSERT NOT NEW.finished,'Internal invariant violated';
+ INSERT INTO
+ purse_actions
+ (purse_pub
+ ,action_date)
+ VALUES
+ (NEW.purse_pub
+ ,NEW.purse_expiration);
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION purse_requests_insert_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.purse_requests_insert_trigger() IS 'When a purse is created, insert it into the purse_action table to take action when the purse expires.';
+
+
+--
+-- Name: purse_requests_on_update_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.purse_requests_on_update_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ IF (NEW.finished AND NOT OLD.finished)
+ THEN
+ -- If this purse counted against the reserve's
+ -- quota of purses, decrement the reserve accounting.
+ IF (NEW.in_reserve_quota)
+ THEN
+ UPDATE reserves
+ SET purses_active=purses_active-1
+ WHERE reserve_pub IN
+ (SELECT reserve_pub
+ FROM purse_merges
+ WHERE purse_pub=NEW.purse_pub
+ LIMIT 1);
+ NEW.in_reserve_quota=FALSE;
+ END IF;
+ -- Delete from the purse_actions table, we are done
+ -- with this purse for good.
+ DELETE FROM purse_actions
+ WHERE purse_pub=NEW.purse_pub;
+ RETURN NEW;
+ END IF;
+
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION purse_requests_on_update_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.purse_requests_on_update_trigger() IS 'Trigger the router if the purse is ready. Also removes the entry from the router watchlist once the purse is finished.';
+
+
+--
+-- Name: recoup_delete_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.recoup_delete_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ DELETE FROM recoup_by_reserve
+ WHERE reserve_out_serial_id = OLD.reserve_out_serial_id
+ AND coin_pub = OLD.coin_pub;
+ RETURN OLD;
+END $$;
+
+
+--
+-- Name: FUNCTION recoup_delete_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.recoup_delete_trigger() IS 'Replicate recoup deletions into recoup_by_reserve table.';
+
+
+--
+-- Name: recoup_insert_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.recoup_insert_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ INSERT INTO recoup_by_reserve
+ (reserve_out_serial_id
+ ,coin_pub)
+ VALUES
+ (NEW.reserve_out_serial_id
+ ,NEW.coin_pub);
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION recoup_insert_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.recoup_insert_trigger() IS 'Replicate recoup inserts into recoup_by_reserve table.';
+
+
+--
+-- Name: reserves_out_by_reserve_delete_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.reserves_out_by_reserve_delete_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ DELETE FROM reserves_out_by_reserve
+ WHERE reserve_uuid = OLD.reserve_uuid;
+ RETURN OLD;
+END $$;
+
+
+--
+-- Name: FUNCTION reserves_out_by_reserve_delete_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.reserves_out_by_reserve_delete_trigger() IS 'Replicate reserve_out deletions into reserve_out_by_reserve table.';
+
+
+--
+-- Name: reserves_out_by_reserve_insert_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.reserves_out_by_reserve_insert_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ INSERT INTO reserves_out_by_reserve
+ (reserve_uuid
+ ,h_blind_ev)
+ VALUES
+ (NEW.reserve_uuid
+ ,NEW.h_blind_ev);
+ RETURN NEW;
+END $$;
+
+
+--
+-- Name: FUNCTION reserves_out_by_reserve_insert_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.reserves_out_by_reserve_insert_trigger() IS 'Replicate reserve_out inserts into reserve_out_by_reserve table.';
+
+
+--
+-- Name: wire_out_delete_trigger(); Type: FUNCTION; Schema: public; Owner: -
+--
+
+CREATE FUNCTION public.wire_out_delete_trigger() RETURNS trigger
+ LANGUAGE plpgsql
+ AS $$
+BEGIN
+ DELETE FROM aggregation_tracking
+ WHERE wtid_raw = OLD.wtid_raw;
+ RETURN OLD;
+END $$;
+
+
+--
+-- Name: FUNCTION wire_out_delete_trigger(); Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON FUNCTION public.wire_out_delete_trigger() IS 'Replicate reserve_out deletions into aggregation_tracking. This replaces an earlier use of an ON DELETE CASCADE that required a DEFERRABLE constraint and conflicted with nice partitioning.';
+
+
SET default_tablespace = '';
SET default_table_access_method = heap;
@@ -316,14 +5515,89 @@ COMMENT ON COLUMN _v.patches.conflicts IS 'List of patches that conflict with gi
--
+-- Name: account_merges; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.account_merges (
+ account_merge_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ CONSTRAINT account_merges_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT account_merges_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT account_merges_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE account_merges; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.account_merges IS 'Merge requests where a purse- and account-owner requested merging the purse into the account';
+
+
+--
+-- Name: COLUMN account_merges.reserve_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.account_merges.reserve_pub IS 'public key of the target reserve';
+
+
+--
+-- Name: COLUMN account_merges.reserve_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.account_merges.reserve_sig IS 'signature by the reserve private key affirming the merge, of type TALER_SIGNATURE_WALLET_ACCOUNT_MERGE';
+
+
+--
+-- Name: COLUMN account_merges.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.account_merges.purse_pub IS 'public key of the purse';
+
+
+--
+-- Name: account_merges_account_merge_request_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.account_merges ALTER COLUMN account_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.account_merges_account_merge_request_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: account_merges_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.account_merges_default (
+ account_merge_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ CONSTRAINT account_merges_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT account_merges_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT account_merges_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.account_merges ATTACH PARTITION public.account_merges_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
-- Name: aggregation_tracking; Type: TABLE; Schema: public; Owner: -
--
CREATE TABLE public.aggregation_tracking (
aggregation_serial_id bigint NOT NULL,
deposit_serial_id bigint NOT NULL,
- wtid_raw bytea
-);
+ wtid_raw bytea NOT NULL
+)
+PARTITION BY HASH (deposit_serial_id);
--
@@ -337,26 +5611,86 @@ COMMENT ON TABLE public.aggregation_tracking IS 'mapping from wire transfer iden
-- Name: COLUMN aggregation_tracking.wtid_raw; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.aggregation_tracking.wtid_raw IS 'We first create entries in the aggregation_tracking table and then finally the wire_out entry once we know the total amount. Hence the constraint must be deferrable and we cannot use a wireout_uuid here, because we do not have it when these rows are created. Changing the logic to first INSERT a dummy row into wire_out and then UPDATEing that row in the same transaction would theoretically reduce per-deposit storage costs by 5 percent (24/~460 bytes).';
+COMMENT ON COLUMN public.aggregation_tracking.wtid_raw IS 'identifier of the wire transfer';
--
-- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.aggregation_tracking_aggregation_serial_id_seq
+ALTER TABLE public.aggregation_tracking ALTER COLUMN aggregation_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.aggregation_tracking_aggregation_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
+
+
+--
+-- Name: aggregation_tracking_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.aggregation_tracking_default (
+ aggregation_serial_id bigint NOT NULL,
+ deposit_serial_id bigint NOT NULL,
+ wtid_raw bytea NOT NULL
+);
+ALTER TABLE ONLY public.aggregation_tracking ATTACH PARTITION public.aggregation_tracking_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: aggregation_transient; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.aggregation_transient (
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ wire_target_h_payto bytea,
+ exchange_account_section text NOT NULL,
+ wtid_raw bytea NOT NULL,
+ CONSTRAINT aggregation_transient_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
+ CONSTRAINT aggregation_transient_wtid_raw_check CHECK ((length(wtid_raw) = 32))
+)
+PARTITION BY HASH (wire_target_h_payto);
--
--- Name: aggregation_tracking_aggregation_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: TABLE aggregation_transient; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.aggregation_tracking_aggregation_serial_id_seq OWNED BY public.aggregation_tracking.aggregation_serial_id;
+COMMENT ON TABLE public.aggregation_transient IS 'aggregations currently happening (lacking wire_out, usually because the amount is too low); this table is not replicated';
+
+
+--
+-- Name: COLUMN aggregation_transient.amount_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.aggregation_transient.amount_val IS 'Sum of all of the aggregated deposits (without deposit fees)';
+
+
+--
+-- Name: COLUMN aggregation_transient.wtid_raw; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.aggregation_transient.wtid_raw IS 'identifier of the wire transfer';
+
+
+--
+-- Name: aggregation_transient_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.aggregation_transient_default (
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ wire_target_h_payto bytea,
+ exchange_account_section text NOT NULL,
+ wtid_raw bytea NOT NULL,
+ CONSTRAINT aggregation_transient_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
+ CONSTRAINT aggregation_transient_wtid_raw_check CHECK ((length(wtid_raw) = 32))
+);
+ALTER TABLE ONLY public.aggregation_transient ATTACH PARTITION public.aggregation_transient_default FOR VALUES WITH (modulus 1, remainder 0);
--
@@ -516,19 +5850,14 @@ COMMENT ON COLUMN public.auditor_denom_sigs.auditor_sig IS 'Signature of the aud
-- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.auditor_denom_sigs_auditor_denom_serial_seq
+ALTER TABLE public.auditor_denom_sigs ALTER COLUMN auditor_denom_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.auditor_denom_sigs_auditor_denom_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: auditor_denom_sigs_auditor_denom_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.auditor_denom_sigs_auditor_denom_serial_seq OWNED BY public.auditor_denom_sigs.auditor_denom_serial;
+ CACHE 1
+);
--
@@ -716,7 +6045,9 @@ CREATE TABLE public.auditor_progress_coin (
last_melt_serial_id bigint DEFAULT 0 NOT NULL,
last_refund_serial_id bigint DEFAULT 0 NOT NULL,
last_recoup_serial_id bigint DEFAULT 0 NOT NULL,
- last_recoup_refresh_serial_id bigint DEFAULT 0 NOT NULL
+ last_recoup_refresh_serial_id bigint DEFAULT 0 NOT NULL,
+ last_purse_deposits_serial_id bigint DEFAULT 0 NOT NULL,
+ last_purse_refunds_serial_id bigint DEFAULT 0 NOT NULL
);
@@ -755,7 +6086,12 @@ CREATE TABLE public.auditor_progress_reserve (
last_reserve_in_serial_id bigint DEFAULT 0 NOT NULL,
last_reserve_out_serial_id bigint DEFAULT 0 NOT NULL,
last_reserve_recoup_serial_id bigint DEFAULT 0 NOT NULL,
- last_reserve_close_serial_id bigint DEFAULT 0 NOT NULL
+ last_reserve_close_serial_id bigint DEFAULT 0 NOT NULL,
+ last_purse_merges_serial_id bigint DEFAULT 0 NOT NULL,
+ last_purse_deposits_serial_id bigint DEFAULT 0 NOT NULL,
+ last_account_merges_serial_id bigint DEFAULT 0 NOT NULL,
+ last_history_requests_serial_id bigint DEFAULT 0 NOT NULL,
+ last_close_requests_serial_id bigint DEFAULT 0 NOT NULL
);
@@ -776,7 +6112,11 @@ CREATE TABLE public.auditor_reserve_balance (
reserve_balance_val bigint NOT NULL,
reserve_balance_frac integer NOT NULL,
withdraw_fee_balance_val bigint NOT NULL,
- withdraw_fee_balance_frac integer NOT NULL
+ withdraw_fee_balance_frac integer NOT NULL,
+ purse_fee_balance_val bigint NOT NULL,
+ purse_fee_balance_frac integer NOT NULL,
+ history_fee_balance_val bigint NOT NULL,
+ history_fee_balance_frac integer NOT NULL
);
@@ -903,19 +6243,14 @@ COMMENT ON COLUMN public.auditors.last_change IS 'Latest time when active status
-- Name: auditors_auditor_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.auditors_auditor_uuid_seq
+ALTER TABLE public.auditors ALTER COLUMN auditor_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.auditors_auditor_uuid_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: auditors_auditor_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.auditors_auditor_uuid_seq OWNED BY public.auditors.auditor_uuid;
+ CACHE 1
+);
--
@@ -1107,6 +6442,239 @@ ALTER SEQUENCE public.auth_user_user_permissions_id_seq OWNED BY public.auth_use
--
+-- Name: close_requests; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.close_requests (
+ close_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ close_timestamp bigint NOT NULL,
+ reserve_sig bytea NOT NULL,
+ close_val bigint NOT NULL,
+ close_frac integer NOT NULL,
+ CONSTRAINT close_requests_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT close_requests_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+)
+PARTITION BY HASH (reserve_pub);
+
+
+--
+-- Name: TABLE close_requests; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.close_requests IS 'Explicit requests by a reserve owner to close a reserve immediately';
+
+
+--
+-- Name: COLUMN close_requests.close_timestamp; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.close_requests.close_timestamp IS 'When the request was created by the client';
+
+
+--
+-- Name: COLUMN close_requests.reserve_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.close_requests.reserve_sig IS 'Signature affirming that the reserve is to be closed';
+
+
+--
+-- Name: COLUMN close_requests.close_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.close_requests.close_val IS 'Balance of the reserve at the time of closing, to be wired to the associated bank account (minus the closing fee)';
+
+
+--
+-- Name: close_requests_close_request_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.close_requests ALTER COLUMN close_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.close_requests_close_request_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: close_requests_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.close_requests_default (
+ close_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ close_timestamp bigint NOT NULL,
+ reserve_sig bytea NOT NULL,
+ close_val bigint NOT NULL,
+ close_frac integer NOT NULL,
+ CONSTRAINT close_requests_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT close_requests_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.close_requests ATTACH PARTITION public.close_requests_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: contracts; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.contracts (
+ contract_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ pub_ckey bytea NOT NULL,
+ contract_sig bytea NOT NULL,
+ e_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ CONSTRAINT contracts_contract_sig_check CHECK ((length(contract_sig) = 64)),
+ CONSTRAINT contracts_pub_ckey_check CHECK ((length(pub_ckey) = 32)),
+ CONSTRAINT contracts_purse_pub_check CHECK ((length(purse_pub) = 32))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE contracts; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.contracts IS 'encrypted contracts associated with purses';
+
+
+--
+-- Name: COLUMN contracts.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.contracts.purse_pub IS 'public key of the purse that the contract is associated with';
+
+
+--
+-- Name: COLUMN contracts.pub_ckey; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.contracts.pub_ckey IS 'Public ECDH key used to encrypt the contract, to be used with the purse private key for decryption';
+
+
+--
+-- Name: COLUMN contracts.contract_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.contracts.contract_sig IS 'signature over the encrypted contract by the purse contract key';
+
+
+--
+-- Name: COLUMN contracts.e_contract; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.contracts.e_contract IS 'AES-GCM encrypted contract terms (contains gzip compressed JSON after decryption)';
+
+
+--
+-- Name: contracts_contract_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.contracts ALTER COLUMN contract_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.contracts_contract_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: contracts_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.contracts_default (
+ contract_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ pub_ckey bytea NOT NULL,
+ contract_sig bytea NOT NULL,
+ e_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ CONSTRAINT contracts_contract_sig_check CHECK ((length(contract_sig) = 64)),
+ CONSTRAINT contracts_pub_ckey_check CHECK ((length(pub_ckey) = 32)),
+ CONSTRAINT contracts_purse_pub_check CHECK ((length(purse_pub) = 32))
+);
+ALTER TABLE ONLY public.contracts ATTACH PARTITION public.contracts_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: cs_nonce_locks; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.cs_nonce_locks (
+ cs_nonce_lock_serial_id bigint NOT NULL,
+ nonce bytea NOT NULL,
+ op_hash bytea NOT NULL,
+ max_denomination_serial bigint NOT NULL,
+ CONSTRAINT cs_nonce_locks_nonce_check CHECK ((length(nonce) = 32)),
+ CONSTRAINT cs_nonce_locks_op_hash_check CHECK ((length(op_hash) = 64))
+)
+PARTITION BY HASH (nonce);
+
+
+--
+-- Name: TABLE cs_nonce_locks; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.cs_nonce_locks IS 'ensures a Clause Schnorr client nonce is locked for use with an operation identified by a hash';
+
+
+--
+-- Name: COLUMN cs_nonce_locks.nonce; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.cs_nonce_locks.nonce IS 'actual nonce submitted by the client';
+
+
+--
+-- Name: COLUMN cs_nonce_locks.op_hash; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.cs_nonce_locks.op_hash IS 'hash (RC for refresh, blind coin hash for withdraw) the nonce may be used with';
+
+
+--
+-- Name: COLUMN cs_nonce_locks.max_denomination_serial; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.cs_nonce_locks.max_denomination_serial IS 'Maximum number of a CS denomination serial the nonce could be used with, for GC';
+
+
+--
+-- Name: cs_nonce_locks_cs_nonce_lock_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.cs_nonce_locks ALTER COLUMN cs_nonce_lock_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.cs_nonce_locks_cs_nonce_lock_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: cs_nonce_locks_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.cs_nonce_locks_default (
+ cs_nonce_lock_serial_id bigint NOT NULL,
+ nonce bytea NOT NULL,
+ op_hash bytea NOT NULL,
+ max_denomination_serial bigint NOT NULL,
+ CONSTRAINT cs_nonce_locks_nonce_check CHECK ((length(nonce) = 32)),
+ CONSTRAINT cs_nonce_locks_op_hash_check CHECK ((length(op_hash) = 64))
+);
+ALTER TABLE ONLY public.cs_nonce_locks ATTACH PARTITION public.cs_nonce_locks_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
-- Name: denomination_revocations; Type: TABLE; Schema: public; Owner: -
--
@@ -1129,19 +6697,14 @@ COMMENT ON TABLE public.denomination_revocations IS 'remembering which denominat
-- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.denomination_revocations_denom_revocations_serial_id_seq
+ALTER TABLE public.denomination_revocations ALTER COLUMN denom_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.denomination_revocations_denom_revocations_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: denomination_revocations_denom_revocations_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.denomination_revocations_denom_revocations_serial_id_seq OWNED BY public.denomination_revocations.denom_revocations_serial_id;
+ CACHE 1
+);
--
@@ -1152,7 +6715,7 @@ CREATE TABLE public.denominations (
denominations_serial bigint NOT NULL,
denom_pub_hash bytea NOT NULL,
denom_type integer DEFAULT 1 NOT NULL,
- age_restrictions integer DEFAULT 0 NOT NULL,
+ age_mask integer DEFAULT 0 NOT NULL,
denom_pub bytea NOT NULL,
master_sig bytea NOT NULL,
valid_from bigint NOT NULL,
@@ -1196,29 +6759,24 @@ COMMENT ON COLUMN public.denominations.denom_type IS 'determines cipher type for
--
--- Name: COLUMN denominations.age_restrictions; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN denominations.age_mask; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.denominations.age_restrictions IS 'bitmask with the age restrictions that are being used for this denomination; 0 if denomination does not support the use of age restrictions';
+COMMENT ON COLUMN public.denominations.age_mask IS 'bitmask with the age restrictions that are being used for this denomination; 0 if denomination does not support the use of age restrictions';
--
-- Name: denominations_denominations_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.denominations_denominations_serial_seq
+ALTER TABLE public.denominations ALTER COLUMN denominations_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.denominations_denominations_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: denominations_denominations_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.denominations_denominations_serial_seq OWNED BY public.denominations.denominations_serial;
+ CACHE 1
+);
--
@@ -1285,6 +6843,7 @@ ALTER SEQUENCE public.deposit_confirmations_serial_id_seq OWNED BY public.deposi
CREATE TABLE public.deposits (
deposit_serial_id bigint NOT NULL,
shard bigint NOT NULL,
+ coin_pub bytea NOT NULL,
known_coin_id bigint NOT NULL,
amount_with_fee_val bigint NOT NULL,
amount_with_fee_frac integer NOT NULL,
@@ -1296,16 +6855,18 @@ CREATE TABLE public.deposits (
h_contract_terms bytea NOT NULL,
coin_sig bytea NOT NULL,
wire_salt bytea NOT NULL,
- wire_target_serial_id bigint NOT NULL,
- tiny boolean DEFAULT false NOT NULL,
+ wire_target_h_payto bytea,
done boolean DEFAULT false NOT NULL,
extension_blocked boolean DEFAULT false NOT NULL,
extension_details_serial_id bigint,
+ CONSTRAINT deposits_coin_pub_check CHECK ((length(coin_pub) = 32)),
CONSTRAINT deposits_coin_sig_check CHECK ((length(coin_sig) = 64)),
CONSTRAINT deposits_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
CONSTRAINT deposits_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
- CONSTRAINT deposits_wire_salt_check CHECK ((length(wire_salt) = 16))
-);
+ CONSTRAINT deposits_wire_salt_check CHECK ((length(wire_salt) = 16)),
+ CONSTRAINT deposits_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32))
+)
+PARTITION BY HASH (coin_pub);
--
@@ -1319,28 +6880,28 @@ COMMENT ON TABLE public.deposits IS 'Deposits we have received and for which we
-- Name: COLUMN deposits.shard; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.deposits.shard IS 'Used for load sharding. Should be set based on h_payto and merchant_pub. 64-bit value because we need an *unsigned* 32-bit value.';
+COMMENT ON COLUMN public.deposits.shard IS 'Used for load sharding in the materialized indices. Should be set based on merchant_pub. 64-bit value because we need an *unsigned* 32-bit value.';
--
--- Name: COLUMN deposits.wire_salt; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN deposits.known_coin_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.deposits.wire_salt IS 'Salt used when hashing the payto://-URI to get the h_wire';
+COMMENT ON COLUMN public.deposits.known_coin_id IS 'Used for garbage collection';
--
--- Name: COLUMN deposits.wire_target_serial_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN deposits.wire_salt; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.deposits.wire_target_serial_id IS 'Identifies the target bank account and KYC status';
+COMMENT ON COLUMN public.deposits.wire_salt IS 'Salt used when hashing the payto://-URI to get the h_wire';
--
--- Name: COLUMN deposits.tiny; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN deposits.wire_target_h_payto; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.deposits.tiny IS 'Set to TRUE if we decided that the amount is too small to ever trigger a wire transfer by itself (requires real aggregation)';
+COMMENT ON COLUMN public.deposits.wire_target_h_payto IS 'Identifies the target bank account and KYC status';
--
@@ -1365,22 +6926,122 @@ COMMENT ON COLUMN public.deposits.extension_details_serial_id IS 'References ext
--
+-- Name: deposits_by_ready; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.deposits_by_ready (
+ wire_deadline bigint NOT NULL,
+ shard bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ deposit_serial_id bigint,
+ CONSTRAINT deposits_by_ready_coin_pub_check CHECK ((length(coin_pub) = 32))
+)
+PARTITION BY RANGE (wire_deadline);
+
+
+--
+-- Name: TABLE deposits_by_ready; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.deposits_by_ready IS 'Enables fast lookups for deposits_get_ready, auto-populated via TRIGGER below';
+
+
+--
+-- Name: deposits_by_ready_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.deposits_by_ready_default (
+ wire_deadline bigint NOT NULL,
+ shard bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ deposit_serial_id bigint,
+ CONSTRAINT deposits_by_ready_coin_pub_check CHECK ((length(coin_pub) = 32))
+);
+ALTER TABLE ONLY public.deposits_by_ready ATTACH PARTITION public.deposits_by_ready_default DEFAULT;
+
+
+--
+-- Name: deposits_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.deposits_default (
+ deposit_serial_id bigint NOT NULL,
+ shard bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ known_coin_id bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ wallet_timestamp bigint NOT NULL,
+ exchange_timestamp bigint NOT NULL,
+ refund_deadline bigint NOT NULL,
+ wire_deadline bigint NOT NULL,
+ merchant_pub bytea NOT NULL,
+ h_contract_terms bytea NOT NULL,
+ coin_sig bytea NOT NULL,
+ wire_salt bytea NOT NULL,
+ wire_target_h_payto bytea,
+ done boolean DEFAULT false NOT NULL,
+ extension_blocked boolean DEFAULT false NOT NULL,
+ extension_details_serial_id bigint,
+ CONSTRAINT deposits_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT deposits_coin_sig_check CHECK ((length(coin_sig) = 64)),
+ CONSTRAINT deposits_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
+ CONSTRAINT deposits_merchant_pub_check CHECK ((length(merchant_pub) = 32)),
+ CONSTRAINT deposits_wire_salt_check CHECK ((length(wire_salt) = 16)),
+ CONSTRAINT deposits_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32))
+);
+ALTER TABLE ONLY public.deposits ATTACH PARTITION public.deposits_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
-- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.deposits_deposit_serial_id_seq
+ALTER TABLE public.deposits ALTER COLUMN deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.deposits_deposit_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
+
+
+--
+-- Name: deposits_for_matching; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.deposits_for_matching (
+ refund_deadline bigint NOT NULL,
+ merchant_pub bytea NOT NULL,
+ coin_pub bytea NOT NULL,
+ deposit_serial_id bigint,
+ CONSTRAINT deposits_for_matching_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT deposits_for_matching_merchant_pub_check CHECK ((length(merchant_pub) = 32))
+)
+PARTITION BY RANGE (refund_deadline);
+
+
+--
+-- Name: TABLE deposits_for_matching; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.deposits_for_matching IS 'Enables fast lookups for deposits_iterate_matching, auto-populated via TRIGGER below';
--
--- Name: deposits_deposit_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: deposits_for_matching_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.deposits_deposit_serial_id_seq OWNED BY public.deposits.deposit_serial_id;
+CREATE TABLE public.deposits_for_matching_default (
+ refund_deadline bigint NOT NULL,
+ merchant_pub bytea NOT NULL,
+ coin_pub bytea NOT NULL,
+ deposit_serial_id bigint,
+ CONSTRAINT deposits_for_matching_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT deposits_for_matching_merchant_pub_check CHECK ((length(merchant_pub) = 32))
+);
+ALTER TABLE ONLY public.deposits_for_matching ATTACH PARTITION public.deposits_for_matching_default DEFAULT;
--
@@ -1517,19 +7178,14 @@ COMMENT ON COLUMN public.exchange_sign_keys.expire_legal IS 'Time when this onli
-- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.exchange_sign_keys_esk_serial_seq
+ALTER TABLE public.exchange_sign_keys ALTER COLUMN esk_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.exchange_sign_keys_esk_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: exchange_sign_keys_esk_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.exchange_sign_keys_esk_serial_seq OWNED BY public.exchange_sign_keys.esk_serial;
+ CACHE 1
+);
--
@@ -1539,7 +7195,8 @@ ALTER SEQUENCE public.exchange_sign_keys_esk_serial_seq OWNED BY public.exchange
CREATE TABLE public.extension_details (
extension_details_serial_id bigint NOT NULL,
extension_options character varying
-);
+)
+PARTITION BY HASH (extension_details_serial_id);
--
@@ -1557,22 +7214,203 @@ COMMENT ON COLUMN public.extension_details.extension_options IS 'JSON object wit
--
+-- Name: extension_details_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.extension_details_default (
+ extension_details_serial_id bigint NOT NULL,
+ extension_options character varying
+);
+ALTER TABLE ONLY public.extension_details ATTACH PARTITION public.extension_details_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
-- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.extension_details_extension_details_serial_id_seq
+ALTER TABLE public.extension_details ALTER COLUMN extension_details_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.extension_details_extension_details_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: extension_details_extension_details_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: extensions; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.extension_details_extension_details_serial_id_seq OWNED BY public.extension_details.extension_details_serial_id;
+CREATE TABLE public.extensions (
+ extension_id bigint NOT NULL,
+ name character varying NOT NULL,
+ config bytea
+);
+
+
+--
+-- Name: TABLE extensions; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.extensions IS 'Configurations of the activated extensions';
+
+
+--
+-- Name: COLUMN extensions.name; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.extensions.name IS 'Name of the extension';
+
+
+--
+-- Name: COLUMN extensions.config; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.extensions.config IS 'Configuration of the extension as JSON-blob, maybe NULL';
+
+
+--
+-- Name: extensions_extension_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.extensions ALTER COLUMN extension_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.extensions_extension_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: global_fee; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.global_fee (
+ global_fee_serial bigint NOT NULL,
+ start_date bigint NOT NULL,
+ end_date bigint NOT NULL,
+ history_fee_val bigint NOT NULL,
+ history_fee_frac integer NOT NULL,
+ kyc_fee_val bigint NOT NULL,
+ kyc_fee_frac integer NOT NULL,
+ account_fee_val bigint NOT NULL,
+ account_fee_frac integer NOT NULL,
+ purse_fee_val bigint NOT NULL,
+ purse_fee_frac integer NOT NULL,
+ purse_timeout bigint NOT NULL,
+ kyc_timeout bigint NOT NULL,
+ history_expiration bigint NOT NULL,
+ purse_account_limit integer NOT NULL,
+ master_sig bytea NOT NULL,
+ CONSTRAINT global_fee_master_sig_check CHECK ((length(master_sig) = 64))
+);
+
+
+--
+-- Name: TABLE global_fee; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.global_fee IS 'list of the global fees of this exchange, by date';
+
+
+--
+-- Name: COLUMN global_fee.global_fee_serial; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.global_fee.global_fee_serial IS 'needed for exchange-auditor replication logic';
+
+
+--
+-- Name: global_fee_global_fee_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.global_fee ALTER COLUMN global_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.global_fee_global_fee_serial_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: history_requests; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.history_requests (
+ history_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ request_timestamp bigint NOT NULL,
+ reserve_sig bytea NOT NULL,
+ history_fee_val bigint NOT NULL,
+ history_fee_frac integer NOT NULL,
+ CONSTRAINT history_requests_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT history_requests_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+)
+PARTITION BY HASH (reserve_pub);
+
+
+--
+-- Name: TABLE history_requests; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.history_requests IS 'Paid history requests issued by a client against a reserve';
+
+
+--
+-- Name: COLUMN history_requests.request_timestamp; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.history_requests.request_timestamp IS 'When was the history request made';
+
+
+--
+-- Name: COLUMN history_requests.reserve_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.history_requests.reserve_sig IS 'Signature approving payment for the history request';
+
+
+--
+-- Name: COLUMN history_requests.history_fee_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.history_requests.history_fee_val IS 'History fee approved by the signature';
+
+
+--
+-- Name: history_requests_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.history_requests_default (
+ history_request_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ request_timestamp bigint NOT NULL,
+ reserve_sig bytea NOT NULL,
+ history_fee_val bigint NOT NULL,
+ history_fee_frac integer NOT NULL,
+ CONSTRAINT history_requests_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT history_requests_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.history_requests ATTACH PARTITION public.history_requests_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: history_requests_history_request_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.history_requests ALTER COLUMN history_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.history_requests_history_request_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -1581,13 +7419,16 @@ ALTER SEQUENCE public.extension_details_extension_details_serial_id_seq OWNED BY
CREATE TABLE public.known_coins (
known_coin_id bigint NOT NULL,
- coin_pub bytea NOT NULL,
- age_hash bytea,
denominations_serial bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ age_commitment_hash bytea,
denom_sig bytea NOT NULL,
- CONSTRAINT known_coins_age_hash_check CHECK ((length(age_hash) = 32)),
+ remaining_val bigint DEFAULT 0 NOT NULL,
+ remaining_frac integer DEFAULT 0 NOT NULL,
+ CONSTRAINT known_coins_age_commitment_hash_check CHECK ((length(age_commitment_hash) = 32)),
CONSTRAINT known_coins_coin_pub_check CHECK ((length(coin_pub) = 32))
-);
+)
+PARTITION BY HASH (coin_pub);
--
@@ -1598,6 +7439,13 @@ COMMENT ON TABLE public.known_coins IS 'information about coins and their signat
--
+-- Name: COLUMN known_coins.denominations_serial; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.known_coins.denominations_serial IS 'Denomination of the coin, determines the value of the original coin and applicable fees for coin-specific operations.';
+
+
+--
-- Name: COLUMN known_coins.coin_pub; Type: COMMENT; Schema: public; Owner: -
--
@@ -1605,10 +7453,10 @@ COMMENT ON COLUMN public.known_coins.coin_pub IS 'EdDSA public key of the coin';
--
--- Name: COLUMN known_coins.age_hash; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN known_coins.age_commitment_hash; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.known_coins.age_hash IS 'Optional hash for age restrictions as per DD 24 (active if denom_type has the respective bit set)';
+COMMENT ON COLUMN public.known_coins.age_commitment_hash IS 'Optional hash of the age commitment for age restrictions as per DD 24 (active if denom_type has the respective bit set)';
--
@@ -1619,22 +7467,42 @@ COMMENT ON COLUMN public.known_coins.denom_sig IS 'This is the signature of the
--
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN known_coins.remaining_val; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.known_coins_known_coin_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.known_coins.remaining_val IS 'Value of the coin that remains to be spent';
--
--- Name: known_coins_known_coin_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: known_coins_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.known_coins_known_coin_id_seq OWNED BY public.known_coins.known_coin_id;
+CREATE TABLE public.known_coins_default (
+ known_coin_id bigint NOT NULL,
+ denominations_serial bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ age_commitment_hash bytea,
+ denom_sig bytea NOT NULL,
+ remaining_val bigint DEFAULT 0 NOT NULL,
+ remaining_frac integer DEFAULT 0 NOT NULL,
+ CONSTRAINT known_coins_age_commitment_hash_check CHECK ((length(age_commitment_hash) = 32)),
+ CONSTRAINT known_coins_coin_pub_check CHECK ((length(coin_pub) = 32))
+);
+ALTER TABLE ONLY public.known_coins ATTACH PARTITION public.known_coins_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: known_coins_known_coin_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.known_coins ALTER COLUMN known_coin_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.known_coins_known_coin_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -1692,19 +7560,14 @@ COMMENT ON COLUMN public.merchant_accounts.active IS 'true if we actively use th
-- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_accounts_account_serial_seq
+ALTER TABLE public.merchant_accounts ALTER COLUMN account_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_accounts_account_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_accounts_account_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_accounts_account_serial_seq OWNED BY public.merchant_accounts.account_serial;
+ CACHE 1
+);
--
@@ -1909,19 +7772,14 @@ COMMENT ON COLUMN public.merchant_deposits.exchange_sig IS 'Signature of the exc
-- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_deposits_deposit_serial_seq
+ALTER TABLE public.merchant_deposits ALTER COLUMN deposit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_deposits_deposit_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_deposits_deposit_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_deposits_deposit_serial_seq OWNED BY public.merchant_deposits.deposit_serial;
+ CACHE 1
+);
--
@@ -1960,19 +7818,14 @@ COMMENT ON COLUMN public.merchant_exchange_signing_keys.master_pub IS 'Master pu
-- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_exchange_signing_keys_signkey_serial_seq
+ALTER TABLE public.merchant_exchange_signing_keys ALTER COLUMN signkey_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_exchange_signing_keys_signkey_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_exchange_signing_keys_signkey_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_exchange_signing_keys_signkey_serial_seq OWNED BY public.merchant_exchange_signing_keys.signkey_serial;
+ CACHE 1
+);
--
@@ -1989,6 +7842,8 @@ CREATE TABLE public.merchant_exchange_wire_fees (
wire_fee_frac integer NOT NULL,
closing_fee_val bigint NOT NULL,
closing_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
master_sig bytea NOT NULL,
CONSTRAINT merchant_exchange_wire_fees_h_wire_method_check CHECK ((length(h_wire_method) = 64)),
CONSTRAINT merchant_exchange_wire_fees_master_pub_check CHECK ((length(master_pub) = 32)),
@@ -2014,19 +7869,14 @@ COMMENT ON COLUMN public.merchant_exchange_wire_fees.master_pub IS 'Master publi
-- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_exchange_wire_fees_wirefee_serial_seq
+ALTER TABLE public.merchant_exchange_wire_fees ALTER COLUMN wirefee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_exchange_wire_fees_wirefee_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_exchange_wire_fees_wirefee_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_exchange_wire_fees_wirefee_serial_seq OWNED BY public.merchant_exchange_wire_fees.wirefee_serial;
+ CACHE 1
+);
--
@@ -2036,6 +7886,8 @@ ALTER SEQUENCE public.merchant_exchange_wire_fees_wirefee_serial_seq OWNED BY pu
CREATE TABLE public.merchant_instances (
merchant_serial bigint NOT NULL,
merchant_pub bytea NOT NULL,
+ auth_hash bytea,
+ auth_salt bytea,
merchant_id character varying NOT NULL,
merchant_name character varying NOT NULL,
address bytea NOT NULL,
@@ -2047,8 +7899,9 @@ CREATE TABLE public.merchant_instances (
default_wire_fee_amortization integer NOT NULL,
default_wire_transfer_delay bigint NOT NULL,
default_pay_delay bigint NOT NULL,
- auth_hash bytea,
- auth_salt bytea,
+ website character varying,
+ email character varying,
+ logo bytea,
CONSTRAINT merchant_instances_auth_hash_check CHECK ((length(auth_hash) = 64)),
CONSTRAINT merchant_instances_auth_salt_check CHECK ((length(auth_salt) = 32)),
CONSTRAINT merchant_instances_merchant_pub_check CHECK ((length(merchant_pub) = 32))
@@ -2063,6 +7916,20 @@ COMMENT ON TABLE public.merchant_instances IS 'all the instances supported by th
--
+-- Name: COLUMN merchant_instances.auth_hash; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.merchant_instances.auth_hash IS 'hash used for merchant back office Authorization, NULL for no check';
+
+
+--
+-- Name: COLUMN merchant_instances.auth_salt; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.merchant_instances.auth_salt IS 'salt to use when hashing Authorization header before comparing with auth_hash';
+
+
+--
-- Name: COLUMN merchant_instances.merchant_id; Type: COMMENT; Schema: public; Owner: -
--
@@ -2091,36 +7958,38 @@ COMMENT ON COLUMN public.merchant_instances.jurisdiction IS 'jurisdiction of the
--
--- Name: COLUMN merchant_instances.auth_hash; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN merchant_instances.website; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.merchant_instances.auth_hash IS 'hash used for merchant back office Authorization, NULL for no check';
+COMMENT ON COLUMN public.merchant_instances.website IS 'merchant site URL';
--
--- Name: COLUMN merchant_instances.auth_salt; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN merchant_instances.email; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.merchant_instances.auth_salt IS 'salt to use when hashing Authorization header before comparing with auth_hash';
+COMMENT ON COLUMN public.merchant_instances.email IS 'email';
--
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN merchant_instances.logo; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_instances_merchant_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.merchant_instances.logo IS 'data image url';
--
--- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: merchant_instances_merchant_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.merchant_instances_merchant_serial_seq OWNED BY public.merchant_instances.merchant_serial;
+ALTER TABLE public.merchant_instances ALTER COLUMN merchant_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_instances_merchant_serial_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -2142,7 +8011,8 @@ CREATE TABLE public.merchant_inventory (
total_sold bigint DEFAULT 0 NOT NULL,
total_lost bigint DEFAULT 0 NOT NULL,
address bytea NOT NULL,
- next_restock bigint NOT NULL
+ next_restock bigint NOT NULL,
+ minimum_age integer DEFAULT 0 NOT NULL
);
@@ -2231,6 +8101,13 @@ COMMENT ON COLUMN public.merchant_inventory.next_restock IS 'GNUnet absolute tim
--
+-- Name: COLUMN merchant_inventory.minimum_age; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.merchant_inventory.minimum_age IS 'Minimum age of the customer in years, to be used if an exchange supports the age restriction extension.';
+
+
+--
-- Name: merchant_inventory_locks; Type: TABLE; Schema: public; Owner: -
--
@@ -2268,19 +8145,14 @@ COMMENT ON COLUMN public.merchant_inventory_locks.expiration IS 'when does this
-- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_inventory_product_serial_seq
+ALTER TABLE public.merchant_inventory ALTER COLUMN product_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_inventory_product_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_inventory_product_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_inventory_product_serial_seq OWNED BY public.merchant_inventory.product_serial;
+ CACHE 1
+);
--
@@ -2379,19 +8251,14 @@ COMMENT ON COLUMN public.merchant_kyc.exchange_url IS 'Which exchange base URL i
-- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_kyc_kyc_serial_id_seq
+ALTER TABLE public.merchant_kyc ALTER COLUMN kyc_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_kyc_kyc_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_kyc_kyc_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_kyc_kyc_serial_id_seq OWNED BY public.merchant_kyc.kyc_serial_id;
+ CACHE 1
+);
--
@@ -2483,19 +8350,14 @@ COMMENT ON COLUMN public.merchant_orders.contract_terms IS 'Claiming changes the
-- Name: merchant_orders_order_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_orders_order_serial_seq
+ALTER TABLE public.merchant_orders ALTER COLUMN order_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_orders_order_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_orders_order_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_orders_order_serial_seq OWNED BY public.merchant_orders.order_serial;
+ CACHE 1
+);
--
@@ -2551,19 +8413,14 @@ COMMENT ON COLUMN public.merchant_refunds.refund_timestamp IS 'Needed for groupi
-- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_refunds_refund_serial_seq
+ALTER TABLE public.merchant_refunds ALTER COLUMN refund_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_refunds_refund_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_refunds_refund_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_refunds_refund_serial_seq OWNED BY public.merchant_refunds.refund_serial;
+ CACHE 1
+);
--
@@ -2609,19 +8466,14 @@ COMMENT ON TABLE public.merchant_tip_pickups IS 'tips that have been picked up';
-- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_tip_pickups_pickup_serial_seq
+ALTER TABLE public.merchant_tip_pickups ALTER COLUMN pickup_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_tip_pickups_pickup_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_tip_pickups_pickup_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_tip_pickups_pickup_serial_seq OWNED BY public.merchant_tip_pickups.pickup_serial;
+ CACHE 1
+);
--
@@ -2712,19 +8564,14 @@ COMMENT ON COLUMN public.merchant_tip_reserves.tips_picked_up_val IS 'Total amou
-- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_tip_reserves_reserve_serial_seq
+ALTER TABLE public.merchant_tip_reserves ALTER COLUMN reserve_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_tip_reserves_reserve_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_tip_reserves_reserve_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_tip_reserves_reserve_serial_seq OWNED BY public.merchant_tip_reserves.reserve_serial;
+ CACHE 1
+);
--
@@ -2786,19 +8633,14 @@ COMMENT ON COLUMN public.merchant_tips.picked_up_val IS 'Tip amount left to be p
-- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_tips_tip_serial_seq
+ALTER TABLE public.merchant_tips ALTER COLUMN tip_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_tips_tip_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: merchant_tips_tip_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.merchant_tips_tip_serial_seq OWNED BY public.merchant_tips.tip_serial;
+ CACHE 1
+);
--
@@ -2810,10 +8652,10 @@ CREATE TABLE public.merchant_transfer_signatures (
signkey_serial bigint NOT NULL,
wire_fee_val bigint NOT NULL,
wire_fee_frac integer NOT NULL,
- execution_time bigint NOT NULL,
- exchange_sig bytea NOT NULL,
credit_amount_val bigint NOT NULL,
credit_amount_frac integer NOT NULL,
+ execution_time bigint NOT NULL,
+ exchange_sig bytea NOT NULL,
CONSTRAINT merchant_transfer_signatures_exchange_sig_check CHECK ((length(exchange_sig) = 64))
);
@@ -2826,6 +8668,13 @@ COMMENT ON TABLE public.merchant_transfer_signatures IS 'table represents the ma
--
+-- Name: COLUMN merchant_transfer_signatures.credit_amount_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.merchant_transfer_signatures.credit_amount_val IS 'actual value of the (aggregated) wire transfer, excluding the wire fee, according to the exchange';
+
+
+--
-- Name: COLUMN merchant_transfer_signatures.execution_time; Type: COMMENT; Schema: public; Owner: -
--
@@ -2896,7 +8745,7 @@ COMMENT ON TABLE public.merchant_transfers IS 'table represents the information
-- Name: COLUMN merchant_transfers.credit_amount_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.merchant_transfers.credit_amount_val IS 'actual value of the (aggregated) wire transfer, excluding the wire fee, according to the exchange';
+COMMENT ON COLUMN public.merchant_transfers.credit_amount_val IS 'actual value of the (aggregated) wire transfer, excluding the wire fee, according to the merchant';
--
@@ -2917,19 +8766,152 @@ COMMENT ON COLUMN public.merchant_transfers.confirmed IS 'true once the merchant
-- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.merchant_transfers_credit_serial_seq
+ALTER TABLE public.merchant_transfers ALTER COLUMN credit_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.merchant_transfers_credit_serial_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
+
+
+--
+-- Name: partner_accounts; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.partner_accounts (
+ payto_uri character varying NOT NULL,
+ partner_serial_id bigint,
+ partner_master_sig bytea,
+ last_seen bigint NOT NULL,
+ CONSTRAINT partner_accounts_partner_master_sig_check CHECK ((length(partner_master_sig) = 64))
+);
+
+
+--
+-- Name: TABLE partner_accounts; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.partner_accounts IS 'Table with bank accounts of the partner exchange. Entries never expire as we need to remember the signature for the auditor.';
+
+
+--
+-- Name: COLUMN partner_accounts.payto_uri; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partner_accounts.payto_uri IS 'payto URI (RFC 8905) with the bank account of the partner exchange.';
+
+
+--
+-- Name: COLUMN partner_accounts.partner_master_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partner_accounts.partner_master_sig IS 'Signature of purpose TALER_SIGNATURE_MASTER_WIRE_DETAILS by the partner master public key';
+
+
+--
+-- Name: COLUMN partner_accounts.last_seen; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partner_accounts.last_seen IS 'Last time we saw this account as being active at the partner exchange. Used to select the most recent entry, and to detect when we should check again.';
+
+
+--
+-- Name: partners; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.partners (
+ partner_serial_id bigint NOT NULL,
+ partner_master_pub bytea NOT NULL,
+ start_date bigint NOT NULL,
+ end_date bigint NOT NULL,
+ next_wad bigint DEFAULT 0 NOT NULL,
+ wad_frequency bigint NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ master_sig bytea NOT NULL,
+ partner_base_url text NOT NULL,
+ CONSTRAINT partners_master_sig_check CHECK ((length(master_sig) = 64)),
+ CONSTRAINT partners_partner_master_pub_check CHECK ((length(partner_master_pub) = 32))
+);
+
+
+--
+-- Name: TABLE partners; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.partners IS 'exchanges we do wad transfers to';
+
+
+--
+-- Name: COLUMN partners.partner_master_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.partner_master_pub IS 'offline master public key of the partner';
+
+
+--
+-- Name: COLUMN partners.start_date; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.start_date IS 'starting date of the partnership';
+
+
+--
+-- Name: COLUMN partners.end_date; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.end_date IS 'end date of the partnership';
+
+
+--
+-- Name: COLUMN partners.next_wad; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.next_wad IS 'at what time should we do the next wad transfer to this partner (frequently updated); set to forever after the end_date';
+
+
+--
+-- Name: COLUMN partners.wad_frequency; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.wad_frequency IS 'how often do we promise to do wad transfers';
+
+
+--
+-- Name: COLUMN partners.wad_fee_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.wad_fee_val IS 'how high is the fee for a wallet to be added to a wad to this partner';
+
+
+--
+-- Name: COLUMN partners.master_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.master_sig IS 'signature of our master public key affirming the partnership, of purpose TALER_SIGNATURE_MASTER_PARTNER_DETAILS';
+
+
+--
+-- Name: COLUMN partners.partner_base_url; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.partners.partner_base_url IS 'base URL of the REST API for this partner';
--
--- Name: merchant_transfers_credit_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: partners_partner_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.merchant_transfers_credit_serial_seq OWNED BY public.merchant_transfers.credit_serial;
+ALTER TABLE public.partners ALTER COLUMN partner_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.partners_partner_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -2938,11 +8920,12 @@ ALTER SEQUENCE public.merchant_transfers_credit_serial_seq OWNED BY public.merch
CREATE TABLE public.prewire (
prewire_uuid bigint NOT NULL,
- type text NOT NULL,
+ wire_method text NOT NULL,
finished boolean DEFAULT false NOT NULL,
failed boolean DEFAULT false NOT NULL,
buf bytea NOT NULL
-);
+)
+PARTITION BY HASH (prewire_uuid);
--
@@ -2974,22 +8957,474 @@ COMMENT ON COLUMN public.prewire.buf IS 'serialized data to send to the bank to
--
+-- Name: prewire_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.prewire_default (
+ prewire_uuid bigint NOT NULL,
+ wire_method text NOT NULL,
+ finished boolean DEFAULT false NOT NULL,
+ failed boolean DEFAULT false NOT NULL,
+ buf bytea NOT NULL
+);
+ALTER TABLE ONLY public.prewire ATTACH PARTITION public.prewire_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
-- Name: prewire_prewire_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.prewire_prewire_uuid_seq
+ALTER TABLE public.prewire ALTER COLUMN prewire_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.prewire_prewire_uuid_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
+
+
+--
+-- Name: purse_actions; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_actions (
+ purse_pub bytea NOT NULL,
+ action_date bigint NOT NULL,
+ partner_serial_id bigint,
+ CONSTRAINT purse_actions_purse_pub_check CHECK ((length(purse_pub) = 32))
+);
--
--- Name: prewire_prewire_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: TABLE purse_actions; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.prewire_prewire_uuid_seq OWNED BY public.prewire.prewire_uuid;
+COMMENT ON TABLE public.purse_actions IS 'purses awaiting some action by the router';
+
+
+--
+-- Name: COLUMN purse_actions.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_actions.purse_pub IS 'public (contract) key of the purse';
+
+
+--
+-- Name: COLUMN purse_actions.action_date; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_actions.action_date IS 'when is the purse ready for action';
+
+
+--
+-- Name: COLUMN purse_actions.partner_serial_id; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_actions.partner_serial_id IS 'wad target of an outgoing wire transfer, 0 for local, NULL if the purse is unmerged and thus the target is still unknown';
+
+
+--
+-- Name: purse_deposits; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_deposits (
+ purse_deposit_serial_id bigint NOT NULL,
+ partner_serial_id bigint,
+ purse_pub bytea NOT NULL,
+ coin_pub bytea NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ coin_sig bytea NOT NULL,
+ CONSTRAINT purse_deposits_coin_sig_check CHECK ((length(coin_sig) = 64)),
+ CONSTRAINT purse_deposits_purse_pub_check CHECK ((length(purse_pub) = 32))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE purse_deposits; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.purse_deposits IS 'Requests depositing coins into a purse';
+
+
+--
+-- Name: COLUMN purse_deposits.partner_serial_id; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_deposits.partner_serial_id IS 'identifies the partner exchange, NULL in case the target purse lives at this exchange';
+
+
+--
+-- Name: COLUMN purse_deposits.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_deposits.purse_pub IS 'Public key of the purse';
+
+
+--
+-- Name: COLUMN purse_deposits.coin_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_deposits.coin_pub IS 'Public key of the coin being deposited';
+
+
+--
+-- Name: COLUMN purse_deposits.amount_with_fee_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_deposits.amount_with_fee_val IS 'Total amount being deposited';
+
+
+--
+-- Name: COLUMN purse_deposits.coin_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_deposits.coin_sig IS 'Signature of the coin affirming the deposit into the purse, of type TALER_SIGNATURE_PURSE_DEPOSIT';
+
+
+--
+-- Name: purse_deposits_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_deposits_default (
+ purse_deposit_serial_id bigint NOT NULL,
+ partner_serial_id bigint,
+ purse_pub bytea NOT NULL,
+ coin_pub bytea NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ coin_sig bytea NOT NULL,
+ CONSTRAINT purse_deposits_coin_sig_check CHECK ((length(coin_sig) = 64)),
+ CONSTRAINT purse_deposits_purse_pub_check CHECK ((length(purse_pub) = 32))
+);
+ALTER TABLE ONLY public.purse_deposits ATTACH PARTITION public.purse_deposits_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: purse_deposits_purse_deposit_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.purse_deposits ALTER COLUMN purse_deposit_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.purse_deposits_purse_deposit_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: purse_merges; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_merges (
+ purse_merge_request_serial_id bigint NOT NULL,
+ partner_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ merge_sig bytea NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ CONSTRAINT purse_merges_merge_sig_check CHECK ((length(merge_sig) = 64)),
+ CONSTRAINT purse_merges_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT purse_merges_reserve_pub_check CHECK ((length(reserve_pub) = 32))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE purse_merges; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.purse_merges IS 'Merge requests where a purse-owner requested merging the purse into the account';
+
+
+--
+-- Name: COLUMN purse_merges.partner_serial_id; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_merges.partner_serial_id IS 'identifies the partner exchange, NULL in case the target reserve lives at this exchange';
+
+
+--
+-- Name: COLUMN purse_merges.reserve_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_merges.reserve_pub IS 'public key of the target reserve';
+
+
+--
+-- Name: COLUMN purse_merges.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_merges.purse_pub IS 'public key of the purse';
+
+
+--
+-- Name: COLUMN purse_merges.merge_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_merges.merge_sig IS 'signature by the purse private key affirming the merge, of type TALER_SIGNATURE_WALLET_PURSE_MERGE';
+
+
+--
+-- Name: COLUMN purse_merges.merge_timestamp; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_merges.merge_timestamp IS 'when was the merge message signed';
+
+
+--
+-- Name: purse_merges_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_merges_default (
+ purse_merge_request_serial_id bigint NOT NULL,
+ partner_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ merge_sig bytea NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ CONSTRAINT purse_merges_merge_sig_check CHECK ((length(merge_sig) = 64)),
+ CONSTRAINT purse_merges_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT purse_merges_reserve_pub_check CHECK ((length(reserve_pub) = 32))
+);
+ALTER TABLE ONLY public.purse_merges ATTACH PARTITION public.purse_merges_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: purse_merges_purse_merge_request_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.purse_merges ALTER COLUMN purse_merge_request_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.purse_merges_purse_merge_request_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: purse_refunds; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_refunds (
+ purse_refunds_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ CONSTRAINT purse_refunds_purse_pub_check CHECK ((length(purse_pub) = 32))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE purse_refunds; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.purse_refunds IS 'Purses that were refunded due to expiration';
+
+
+--
+-- Name: COLUMN purse_refunds.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_refunds.purse_pub IS 'Public key of the purse';
+
+
+--
+-- Name: purse_refunds_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_refunds_default (
+ purse_refunds_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ CONSTRAINT purse_refunds_purse_pub_check CHECK ((length(purse_pub) = 32))
+);
+ALTER TABLE ONLY public.purse_refunds ATTACH PARTITION public.purse_refunds_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: purse_refunds_purse_refunds_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.purse_refunds ALTER COLUMN purse_refunds_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.purse_refunds_purse_refunds_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: purse_requests; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_requests (
+ purse_requests_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ merge_pub bytea NOT NULL,
+ purse_creation bigint NOT NULL,
+ purse_expiration bigint NOT NULL,
+ h_contract_terms bytea NOT NULL,
+ age_limit integer NOT NULL,
+ flags integer NOT NULL,
+ refunded boolean DEFAULT false NOT NULL,
+ finished boolean DEFAULT false NOT NULL,
+ in_reserve_quota boolean DEFAULT false NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ purse_fee_val bigint NOT NULL,
+ purse_fee_frac integer NOT NULL,
+ balance_val bigint DEFAULT 0 NOT NULL,
+ balance_frac integer DEFAULT 0 NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT purse_requests_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
+ CONSTRAINT purse_requests_merge_pub_check CHECK ((length(merge_pub) = 32)),
+ CONSTRAINT purse_requests_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT purse_requests_purse_sig_check CHECK ((length(purse_sig) = 64))
+)
+PARTITION BY HASH (purse_pub);
+
+
+--
+-- Name: TABLE purse_requests; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.purse_requests IS 'Requests establishing purses, associating them with a contract but without a target reserve';
+
+
+--
+-- Name: COLUMN purse_requests.purse_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.purse_pub IS 'Public key of the purse';
+
+
+--
+-- Name: COLUMN purse_requests.purse_creation; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.purse_creation IS 'Local time when the purse was created. Determines applicable purse fees.';
+
+
+--
+-- Name: COLUMN purse_requests.purse_expiration; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.purse_expiration IS 'When the purse is set to expire';
+
+
+--
+-- Name: COLUMN purse_requests.h_contract_terms; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.h_contract_terms IS 'Hash of the contract the parties are to agree to';
+
+
+--
+-- Name: COLUMN purse_requests.flags; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.flags IS 'see the enum TALER_WalletAccountMergeFlags';
+
+
+--
+-- Name: COLUMN purse_requests.refunded; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.refunded IS 'set to TRUE if the purse could not be merged and thus all deposited coins were refunded';
+
+
+--
+-- Name: COLUMN purse_requests.finished; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.finished IS 'set to TRUE once the purse has been merged (into reserve or wad) or the coins were refunded (transfer aborted)';
+
+
+--
+-- Name: COLUMN purse_requests.in_reserve_quota; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.in_reserve_quota IS 'set to TRUE if this purse currently counts against the number of free purses in the respective reserve';
+
+
+--
+-- Name: COLUMN purse_requests.amount_with_fee_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.amount_with_fee_val IS 'Total amount expected to be in the purse';
+
+
+--
+-- Name: COLUMN purse_requests.purse_fee_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.purse_fee_val IS 'Purse fee the client agreed to pay from the reserve (accepted by the exchange at the time the purse was created). Zero if in_reserve_quota is TRUE.';
+
+
+--
+-- Name: COLUMN purse_requests.balance_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.balance_val IS 'Total amount actually in the purse';
+
+
+--
+-- Name: COLUMN purse_requests.purse_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.purse_requests.purse_sig IS 'Signature of the purse affirming the purse parameters, of type TALER_SIGNATURE_PURSE_REQUEST';
+
+
+--
+-- Name: purse_requests_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.purse_requests_default (
+ purse_requests_serial_id bigint NOT NULL,
+ purse_pub bytea NOT NULL,
+ merge_pub bytea NOT NULL,
+ purse_creation bigint NOT NULL,
+ purse_expiration bigint NOT NULL,
+ h_contract_terms bytea NOT NULL,
+ age_limit integer NOT NULL,
+ flags integer NOT NULL,
+ refunded boolean DEFAULT false NOT NULL,
+ finished boolean DEFAULT false NOT NULL,
+ in_reserve_quota boolean DEFAULT false NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ purse_fee_val bigint NOT NULL,
+ purse_fee_frac integer NOT NULL,
+ balance_val bigint DEFAULT 0 NOT NULL,
+ balance_frac integer DEFAULT 0 NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT purse_requests_h_contract_terms_check CHECK ((length(h_contract_terms) = 64)),
+ CONSTRAINT purse_requests_merge_pub_check CHECK ((length(merge_pub) = 32)),
+ CONSTRAINT purse_requests_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT purse_requests_purse_sig_check CHECK ((length(purse_sig) = 64))
+);
+ALTER TABLE ONLY public.purse_requests ATTACH PARTITION public.purse_requests_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: purse_requests_purse_requests_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.purse_requests ALTER COLUMN purse_requests_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.purse_requests_purse_requests_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -2998,56 +9433,118 @@ ALTER SEQUENCE public.prewire_prewire_uuid_seq OWNED BY public.prewire.prewire_u
CREATE TABLE public.recoup (
recoup_uuid bigint NOT NULL,
- known_coin_id bigint NOT NULL,
+ coin_pub bytea NOT NULL,
coin_sig bytea NOT NULL,
coin_blind bytea NOT NULL,
amount_val bigint NOT NULL,
amount_frac integer NOT NULL,
- "timestamp" bigint NOT NULL,
+ recoup_timestamp bigint NOT NULL,
reserve_out_serial_id bigint NOT NULL,
CONSTRAINT recoup_coin_blind_check CHECK ((length(coin_blind) = 32)),
+ CONSTRAINT recoup_coin_pub_check CHECK ((length(coin_pub) = 32)),
CONSTRAINT recoup_coin_sig_check CHECK ((length(coin_sig) = 64))
-);
+)
+PARTITION BY HASH (coin_pub);
--
-- Name: TABLE recoup; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.recoup IS 'Information about recoups that were executed';
+COMMENT ON TABLE public.recoup IS 'Information about recoups that were executed between a coin and a reserve. In this type of recoup, the amount is credited back to the reserve from which the coin originated.';
--
--- Name: COLUMN recoup.known_coin_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN recoup.coin_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.recoup.known_coin_id IS 'Do not CASCADE ON DROP on the known_coin_id, as we may keep the coin alive!';
+COMMENT ON COLUMN public.recoup.coin_pub IS 'Coin that is being debited in the recoup. Do not CASCADE ON DROP on the coin_pub, as we may keep the coin alive!';
+
+
+--
+-- Name: COLUMN recoup.coin_sig; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.recoup.coin_sig IS 'Signature by the coin affirming the recoup, of type TALER_SIGNATURE_WALLET_COIN_RECOUP';
+
+
+--
+-- Name: COLUMN recoup.coin_blind; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.recoup.coin_blind IS 'Denomination blinding key used when creating the blinded coin from the planchet. Secret revealed during the recoup to provide the linkage between the coin and the withdraw operation.';
--
-- Name: COLUMN recoup.reserve_out_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.recoup.reserve_out_serial_id IS 'Identifies the h_blind_ev of the recouped coin.';
+COMMENT ON COLUMN public.recoup.reserve_out_serial_id IS 'Identifies the h_blind_ev of the recouped coin and provides the link to the credited reserve.';
--
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: recoup_by_reserve; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.recoup_recoup_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+CREATE TABLE public.recoup_by_reserve (
+ reserve_out_serial_id bigint NOT NULL,
+ coin_pub bytea,
+ CONSTRAINT recoup_by_reserve_coin_pub_check CHECK ((length(coin_pub) = 32))
+)
+PARTITION BY HASH (reserve_out_serial_id);
+
+
+--
+-- Name: TABLE recoup_by_reserve; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.recoup_by_reserve IS 'Information in this table is strictly redundant with that of recoup, but saved by a different primary key for fast lookups by reserve_out_serial_id.';
+
+
+--
+-- Name: recoup_by_reserve_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.recoup_by_reserve_default (
+ reserve_out_serial_id bigint NOT NULL,
+ coin_pub bytea,
+ CONSTRAINT recoup_by_reserve_coin_pub_check CHECK ((length(coin_pub) = 32))
+);
+ALTER TABLE ONLY public.recoup_by_reserve ATTACH PARTITION public.recoup_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: recoup_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.recoup_default (
+ recoup_uuid bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ coin_sig bytea NOT NULL,
+ coin_blind bytea NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ recoup_timestamp bigint NOT NULL,
+ reserve_out_serial_id bigint NOT NULL,
+ CONSTRAINT recoup_coin_blind_check CHECK ((length(coin_blind) = 32)),
+ CONSTRAINT recoup_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT recoup_coin_sig_check CHECK ((length(coin_sig) = 64))
+);
+ALTER TABLE ONLY public.recoup ATTACH PARTITION public.recoup_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: recoup_recoup_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: recoup_recoup_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.recoup_recoup_uuid_seq OWNED BY public.recoup.recoup_uuid;
+ALTER TABLE public.recoup ALTER COLUMN recoup_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.recoup_recoup_uuid_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3056,49 +9553,89 @@ ALTER SEQUENCE public.recoup_recoup_uuid_seq OWNED BY public.recoup.recoup_uuid;
CREATE TABLE public.recoup_refresh (
recoup_refresh_uuid bigint NOT NULL,
+ coin_pub bytea NOT NULL,
known_coin_id bigint NOT NULL,
coin_sig bytea NOT NULL,
coin_blind bytea NOT NULL,
amount_val bigint NOT NULL,
amount_frac integer NOT NULL,
- "timestamp" bigint NOT NULL,
+ recoup_timestamp bigint NOT NULL,
rrc_serial bigint NOT NULL,
CONSTRAINT recoup_refresh_coin_blind_check CHECK ((length(coin_blind) = 32)),
+ CONSTRAINT recoup_refresh_coin_pub_check CHECK ((length(coin_pub) = 32)),
CONSTRAINT recoup_refresh_coin_sig_check CHECK ((length(coin_sig) = 64))
-);
+)
+PARTITION BY HASH (coin_pub);
+
+
+--
+-- Name: TABLE recoup_refresh; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.recoup_refresh IS 'Table of coins that originated from a refresh operation and that were recouped. Links the (fresh) coin to the melted operation (and thus the old coin). A recoup on a refreshed coin credits the old coin and debits the fresh coin.';
+
+
+--
+-- Name: COLUMN recoup_refresh.coin_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.recoup_refresh.coin_pub IS 'Refreshed coin of a revoked denomination where the residual value is credited to the old coin. Do not CASCADE ON DROP on the coin_pub, as we may keep the coin alive!';
--
-- Name: COLUMN recoup_refresh.known_coin_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.recoup_refresh.known_coin_id IS 'Do not CASCADE ON DROP on the known_coin_id, as we may keep the coin alive!';
+COMMENT ON COLUMN public.recoup_refresh.known_coin_id IS 'FIXME: (To be) used for garbage collection (in the future)';
+
+
+--
+-- Name: COLUMN recoup_refresh.coin_blind; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.recoup_refresh.coin_blind IS 'Denomination blinding key used when creating the blinded coin from the planchet. Secret revealed during the recoup to provide the linkage between the coin and the refresh operation.';
--
-- Name: COLUMN recoup_refresh.rrc_serial; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.recoup_refresh.rrc_serial IS 'Identifies the h_blind_ev of the recouped coin (as h_coin_ev).';
+COMMENT ON COLUMN public.recoup_refresh.rrc_serial IS 'Link to the refresh operation. Also identifies the h_blind_ev of the recouped coin (as h_coin_ev).';
--
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: recoup_refresh_default; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.recoup_refresh_recoup_refresh_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+CREATE TABLE public.recoup_refresh_default (
+ recoup_refresh_uuid bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ known_coin_id bigint NOT NULL,
+ coin_sig bytea NOT NULL,
+ coin_blind bytea NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ recoup_timestamp bigint NOT NULL,
+ rrc_serial bigint NOT NULL,
+ CONSTRAINT recoup_refresh_coin_blind_check CHECK ((length(coin_blind) = 32)),
+ CONSTRAINT recoup_refresh_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT recoup_refresh_coin_sig_check CHECK ((length(coin_sig) = 64))
+);
+ALTER TABLE ONLY public.recoup_refresh ATTACH PARTITION public.recoup_refresh_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: recoup_refresh_recoup_refresh_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.recoup_refresh_recoup_refresh_uuid_seq OWNED BY public.recoup_refresh.recoup_refresh_uuid;
+ALTER TABLE public.recoup_refresh ALTER COLUMN recoup_refresh_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.recoup_refresh_recoup_refresh_uuid_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3108,14 +9645,15 @@ ALTER SEQUENCE public.recoup_refresh_recoup_refresh_uuid_seq OWNED BY public.rec
CREATE TABLE public.refresh_commitments (
melt_serial_id bigint NOT NULL,
rc bytea NOT NULL,
- old_known_coin_id bigint NOT NULL,
+ old_coin_pub bytea NOT NULL,
old_coin_sig bytea NOT NULL,
amount_with_fee_val bigint NOT NULL,
amount_with_fee_frac integer NOT NULL,
noreveal_index integer NOT NULL,
CONSTRAINT refresh_commitments_old_coin_sig_check CHECK ((length(old_coin_sig) = 64)),
CONSTRAINT refresh_commitments_rc_check CHECK ((length(rc) = 64))
-);
+)
+PARTITION BY HASH (rc);
--
@@ -3126,22 +9664,56 @@ COMMENT ON TABLE public.refresh_commitments IS 'Commitments made when melting co
--
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN refresh_commitments.rc; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.refresh_commitments_melt_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.refresh_commitments.rc IS 'Commitment made by the client, hash over the various client inputs in the cut-and-choose protocol';
+
+
+--
+-- Name: COLUMN refresh_commitments.old_coin_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.refresh_commitments.old_coin_pub IS 'Coin being melted in the refresh process.';
--
--- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: COLUMN refresh_commitments.noreveal_index; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.refresh_commitments_melt_serial_id_seq OWNED BY public.refresh_commitments.melt_serial_id;
+COMMENT ON COLUMN public.refresh_commitments.noreveal_index IS 'The gamma value chosen by the exchange in the cut-and-choose protocol';
+
+
+--
+-- Name: refresh_commitments_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.refresh_commitments_default (
+ melt_serial_id bigint NOT NULL,
+ rc bytea NOT NULL,
+ old_coin_pub bytea NOT NULL,
+ old_coin_sig bytea NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ noreveal_index integer NOT NULL,
+ CONSTRAINT refresh_commitments_old_coin_sig_check CHECK ((length(old_coin_sig) = 64)),
+ CONSTRAINT refresh_commitments_rc_check CHECK ((length(rc) = 64))
+);
+ALTER TABLE ONLY public.refresh_commitments ATTACH PARTITION public.refresh_commitments_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: refresh_commitments_melt_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.refresh_commitments ALTER COLUMN melt_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.refresh_commitments_melt_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3157,9 +9729,11 @@ CREATE TABLE public.refresh_revealed_coins (
coin_ev bytea NOT NULL,
h_coin_ev bytea NOT NULL,
ev_sig bytea NOT NULL,
+ ewv bytea NOT NULL,
CONSTRAINT refresh_revealed_coins_h_coin_ev_check CHECK ((length(h_coin_ev) = 64)),
CONSTRAINT refresh_revealed_coins_link_sig_check CHECK ((length(link_sig) = 64))
-);
+)
+PARTITION BY HASH (melt_serial_id);
--
@@ -3212,22 +9786,44 @@ COMMENT ON COLUMN public.refresh_revealed_coins.ev_sig IS 'exchange signature ov
--
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN refresh_revealed_coins.ewv; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.refresh_revealed_coins_rrc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.refresh_revealed_coins.ewv IS 'exchange contributed values in the creation of the fresh coin (see /csr)';
--
--- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: refresh_revealed_coins_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.refresh_revealed_coins_rrc_serial_seq OWNED BY public.refresh_revealed_coins.rrc_serial;
+CREATE TABLE public.refresh_revealed_coins_default (
+ rrc_serial bigint NOT NULL,
+ melt_serial_id bigint NOT NULL,
+ freshcoin_index integer NOT NULL,
+ link_sig bytea NOT NULL,
+ denominations_serial bigint NOT NULL,
+ coin_ev bytea NOT NULL,
+ h_coin_ev bytea NOT NULL,
+ ev_sig bytea NOT NULL,
+ ewv bytea NOT NULL,
+ CONSTRAINT refresh_revealed_coins_h_coin_ev_check CHECK ((length(h_coin_ev) = 64)),
+ CONSTRAINT refresh_revealed_coins_link_sig_check CHECK ((length(link_sig) = 64))
+);
+ALTER TABLE ONLY public.refresh_revealed_coins ATTACH PARTITION public.refresh_revealed_coins_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: refresh_revealed_coins_rrc_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.refresh_revealed_coins ALTER COLUMN rrc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.refresh_revealed_coins_rrc_serial_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3240,7 +9836,8 @@ CREATE TABLE public.refresh_transfer_keys (
transfer_pub bytea NOT NULL,
transfer_privs bytea NOT NULL,
CONSTRAINT refresh_transfer_keys_transfer_pub_check CHECK ((length(transfer_pub) = 32))
-);
+)
+PARTITION BY HASH (melt_serial_id);
--
@@ -3279,22 +9876,31 @@ COMMENT ON COLUMN public.refresh_transfer_keys.transfer_privs IS 'array of TALER
--
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: refresh_transfer_keys_default; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.refresh_transfer_keys_rtc_serial_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+CREATE TABLE public.refresh_transfer_keys_default (
+ rtc_serial bigint NOT NULL,
+ melt_serial_id bigint NOT NULL,
+ transfer_pub bytea NOT NULL,
+ transfer_privs bytea NOT NULL,
+ CONSTRAINT refresh_transfer_keys_transfer_pub_check CHECK ((length(transfer_pub) = 32))
+);
+ALTER TABLE ONLY public.refresh_transfer_keys ATTACH PARTITION public.refresh_transfer_keys_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: refresh_transfer_keys_rtc_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.refresh_transfer_keys_rtc_serial_seq OWNED BY public.refresh_transfer_keys.rtc_serial;
+ALTER TABLE public.refresh_transfer_keys ALTER COLUMN rtc_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.refresh_transfer_keys_rtc_serial_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3303,13 +9909,16 @@ ALTER SEQUENCE public.refresh_transfer_keys_rtc_serial_seq OWNED BY public.refre
CREATE TABLE public.refunds (
refund_serial_id bigint NOT NULL,
+ coin_pub bytea NOT NULL,
deposit_serial_id bigint NOT NULL,
merchant_sig bytea NOT NULL,
rtransaction_id bigint NOT NULL,
amount_with_fee_val bigint NOT NULL,
amount_with_fee_frac integer NOT NULL,
+ CONSTRAINT refunds_coin_pub_check CHECK ((length(coin_pub) = 32)),
CONSTRAINT refunds_merchant_sig_check CHECK ((length(merchant_sig) = 64))
-);
+)
+PARTITION BY HASH (coin_pub);
--
@@ -3323,7 +9932,7 @@ COMMENT ON TABLE public.refunds IS 'Data on coins that were refunded. Technicall
-- Name: COLUMN refunds.deposit_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.refunds.deposit_serial_id IS 'Identifies ONLY the merchant_pub, h_contract_terms and known_coin_id. Multiple deposits may match a refund, this only identifies one of them.';
+COMMENT ON COLUMN public.refunds.deposit_serial_id IS 'Identifies ONLY the merchant_pub, h_contract_terms and coin_pub. Multiple deposits may match a refund, this only identifies one of them.';
--
@@ -3334,22 +9943,35 @@ COMMENT ON COLUMN public.refunds.rtransaction_id IS 'used by the merchant to mak
--
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: refunds_default; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.refunds_refund_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+CREATE TABLE public.refunds_default (
+ refund_serial_id bigint NOT NULL,
+ coin_pub bytea NOT NULL,
+ deposit_serial_id bigint NOT NULL,
+ merchant_sig bytea NOT NULL,
+ rtransaction_id bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ CONSTRAINT refunds_coin_pub_check CHECK ((length(coin_pub) = 32)),
+ CONSTRAINT refunds_merchant_sig_check CHECK ((length(merchant_sig) = 64))
+);
+ALTER TABLE ONLY public.refunds ATTACH PARTITION public.refunds_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: refunds_refund_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: refunds_refund_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.refunds_refund_serial_id_seq OWNED BY public.refunds.refund_serial_id;
+ALTER TABLE public.refunds ALTER COLUMN refund_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.refunds_refund_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3359,12 +9981,18 @@ ALTER SEQUENCE public.refunds_refund_serial_id_seq OWNED BY public.refunds.refun
CREATE TABLE public.reserves (
reserve_uuid bigint NOT NULL,
reserve_pub bytea NOT NULL,
- current_balance_val bigint NOT NULL,
- current_balance_frac integer NOT NULL,
+ current_balance_val bigint DEFAULT 0 NOT NULL,
+ current_balance_frac integer DEFAULT 0 NOT NULL,
+ purses_active bigint DEFAULT 0 NOT NULL,
+ purses_allowed bigint DEFAULT 0 NOT NULL,
+ kyc_required boolean DEFAULT false NOT NULL,
+ kyc_passed boolean DEFAULT false NOT NULL,
+ max_age integer DEFAULT 120 NOT NULL,
expiration_date bigint NOT NULL,
gc_date bigint NOT NULL,
CONSTRAINT reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
-);
+)
+PARTITION BY HASH (reserve_pub);
--
@@ -3375,6 +10003,48 @@ COMMENT ON TABLE public.reserves IS 'Summarizes the balance of a reserve. Update
--
+-- Name: COLUMN reserves.reserve_pub; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.reserve_pub IS 'EdDSA public key of the reserve. Knowledge of the private key implies ownership over the balance.';
+
+
+--
+-- Name: COLUMN reserves.current_balance_val; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.current_balance_val IS 'Current balance remaining with the reserve.';
+
+
+--
+-- Name: COLUMN reserves.purses_active; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.purses_active IS 'Number of purses that were created by this reserve that are not expired and not fully paid.';
+
+
+--
+-- Name: COLUMN reserves.purses_allowed; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.purses_allowed IS 'Number of purses that this reserve is allowed to have active at most.';
+
+
+--
+-- Name: COLUMN reserves.kyc_required; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.kyc_required IS 'True if a KYC check must have been passed before withdrawing from this reserve. Set to true once a reserve received a P2P payment.';
+
+
+--
+-- Name: COLUMN reserves.kyc_passed; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON COLUMN public.reserves.kyc_passed IS 'True once KYC was passed for this reserve. The KYC details are then available via the wire_targets table under the key of wire_target_h_payto which is to be derived from the reserve_pub and the base URL of this exchange.';
+
+
+--
-- Name: COLUMN reserves.expiration_date; Type: COMMENT; Schema: public; Owner: -
--
@@ -3394,16 +10064,18 @@ COMMENT ON COLUMN public.reserves.gc_date IS 'Used to forget all information abo
CREATE TABLE public.reserves_close (
close_uuid bigint NOT NULL,
- reserve_uuid bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
execution_date bigint NOT NULL,
wtid bytea NOT NULL,
- wire_target_serial_id bigint NOT NULL,
+ wire_target_h_payto bytea,
amount_val bigint NOT NULL,
amount_frac integer NOT NULL,
closing_fee_val bigint NOT NULL,
closing_fee_frac integer NOT NULL,
+ CONSTRAINT reserves_close_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
CONSTRAINT reserves_close_wtid_check CHECK ((length(wtid) = 32))
-);
+)
+PARTITION BY HASH (reserve_pub);
--
@@ -3414,29 +10086,65 @@ COMMENT ON TABLE public.reserves_close IS 'wire transfers executed by the reserv
--
--- Name: COLUMN reserves_close.wire_target_serial_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN reserves_close.wire_target_h_payto; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.reserves_close.wire_target_serial_id IS 'Identifies the credited bank account (and KYC status). Note that closing does not depend on KYC.';
+COMMENT ON COLUMN public.reserves_close.wire_target_h_payto IS 'Identifies the credited bank account (and KYC status). Note that closing does not depend on KYC.';
--
-- Name: reserves_close_close_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.reserves_close_close_uuid_seq
+ALTER TABLE public.reserves_close ALTER COLUMN close_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.reserves_close_close_uuid_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: reserves_close_close_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: reserves_close_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.reserves_close_close_uuid_seq OWNED BY public.reserves_close.close_uuid;
+CREATE TABLE public.reserves_close_default (
+ close_uuid bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ execution_date bigint NOT NULL,
+ wtid bytea NOT NULL,
+ wire_target_h_payto bytea,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ closing_fee_val bigint NOT NULL,
+ closing_fee_frac integer NOT NULL,
+ CONSTRAINT reserves_close_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
+ CONSTRAINT reserves_close_wtid_check CHECK ((length(wtid) = 32))
+);
+ALTER TABLE ONLY public.reserves_close ATTACH PARTITION public.reserves_close_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: reserves_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.reserves_default (
+ reserve_uuid bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ current_balance_val bigint DEFAULT 0 NOT NULL,
+ current_balance_frac integer DEFAULT 0 NOT NULL,
+ purses_active bigint DEFAULT 0 NOT NULL,
+ purses_allowed bigint DEFAULT 0 NOT NULL,
+ kyc_required boolean DEFAULT false NOT NULL,
+ kyc_passed boolean DEFAULT false NOT NULL,
+ max_age integer DEFAULT 120 NOT NULL,
+ expiration_date bigint NOT NULL,
+ gc_date bigint NOT NULL,
+ CONSTRAINT reserves_reserve_pub_check CHECK ((length(reserve_pub) = 32))
+);
+ALTER TABLE ONLY public.reserves ATTACH PARTITION public.reserves_default FOR VALUES WITH (modulus 1, remainder 0);
--
@@ -3445,14 +10153,16 @@ ALTER SEQUENCE public.reserves_close_close_uuid_seq OWNED BY public.reserves_clo
CREATE TABLE public.reserves_in (
reserve_in_serial_id bigint NOT NULL,
- reserve_uuid bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
wire_reference bigint NOT NULL,
credit_val bigint NOT NULL,
credit_frac integer NOT NULL,
- wire_source_serial_id bigint NOT NULL,
+ wire_source_h_payto bytea,
exchange_account_section text NOT NULL,
- execution_date bigint NOT NULL
-);
+ execution_date bigint NOT NULL,
+ CONSTRAINT reserves_in_wire_source_h_payto_check CHECK ((length(wire_source_h_payto) = 32))
+)
+PARTITION BY HASH (reserve_pub);
--
@@ -3463,29 +10173,56 @@ COMMENT ON TABLE public.reserves_in IS 'list of transfers of funds into the rese
--
--- Name: COLUMN reserves_in.wire_source_serial_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN reserves_in.reserve_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.reserves_in.wire_source_serial_id IS 'Identifies the debited bank account and KYC status';
+COMMENT ON COLUMN public.reserves_in.reserve_pub IS 'Public key of the reserve. Private key signifies ownership of the remaining balance.';
--
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN reserves_in.credit_val; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.reserves_in_reserve_in_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.reserves_in.credit_val IS 'Amount that was transferred into the reserve';
--
--- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: COLUMN reserves_in.wire_source_h_payto; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.reserves_in_reserve_in_serial_id_seq OWNED BY public.reserves_in.reserve_in_serial_id;
+COMMENT ON COLUMN public.reserves_in.wire_source_h_payto IS 'Identifies the debited bank account and KYC status';
+
+
+--
+-- Name: reserves_in_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.reserves_in_default (
+ reserve_in_serial_id bigint NOT NULL,
+ reserve_pub bytea NOT NULL,
+ wire_reference bigint NOT NULL,
+ credit_val bigint NOT NULL,
+ credit_frac integer NOT NULL,
+ wire_source_h_payto bytea,
+ exchange_account_section text NOT NULL,
+ execution_date bigint NOT NULL,
+ CONSTRAINT reserves_in_wire_source_h_payto_check CHECK ((length(wire_source_h_payto) = 32))
+);
+ALTER TABLE ONLY public.reserves_in ATTACH PARTITION public.reserves_in_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: reserves_in_reserve_in_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.reserves_in ALTER COLUMN reserve_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.reserves_in_reserve_in_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3494,7 +10231,7 @@ ALTER SEQUENCE public.reserves_in_reserve_in_serial_id_seq OWNED BY public.reser
CREATE TABLE public.reserves_out (
reserve_out_serial_id bigint NOT NULL,
- h_blind_ev bytea NOT NULL,
+ h_blind_ev bytea,
denominations_serial bigint NOT NULL,
denom_sig bytea NOT NULL,
reserve_uuid bigint NOT NULL,
@@ -3504,7 +10241,8 @@ CREATE TABLE public.reserves_out (
amount_with_fee_frac integer NOT NULL,
CONSTRAINT reserves_out_h_blind_ev_check CHECK ((length(h_blind_ev) = 64)),
CONSTRAINT reserves_out_reserve_sig_check CHECK ((length(reserve_sig) = 64))
-);
+)
+PARTITION BY HASH (h_blind_ev);
--
@@ -3529,41 +10267,82 @@ COMMENT ON COLUMN public.reserves_out.denominations_serial IS 'We do not CASCADE
--
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: reserves_out_by_reserve; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.reserves_out_reserve_out_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+CREATE TABLE public.reserves_out_by_reserve (
+ reserve_uuid bigint NOT NULL,
+ h_blind_ev bytea,
+ CONSTRAINT reserves_out_by_reserve_h_blind_ev_check CHECK ((length(h_blind_ev) = 64))
+)
+PARTITION BY HASH (reserve_uuid);
--
--- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: TABLE reserves_out_by_reserve; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.reserves_out_reserve_out_serial_id_seq OWNED BY public.reserves_out.reserve_out_serial_id;
+COMMENT ON TABLE public.reserves_out_by_reserve IS 'Information in this table is strictly redundant with that of reserves_out, but saved by a different primary key for fast lookups by reserve public key/uuid.';
--
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: reserves_out_by_reserve_default; Type: TABLE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.reserves_reserve_uuid_seq
+CREATE TABLE public.reserves_out_by_reserve_default (
+ reserve_uuid bigint NOT NULL,
+ h_blind_ev bytea,
+ CONSTRAINT reserves_out_by_reserve_h_blind_ev_check CHECK ((length(h_blind_ev) = 64))
+);
+ALTER TABLE ONLY public.reserves_out_by_reserve ATTACH PARTITION public.reserves_out_by_reserve_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: reserves_out_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.reserves_out_default (
+ reserve_out_serial_id bigint NOT NULL,
+ h_blind_ev bytea,
+ denominations_serial bigint NOT NULL,
+ denom_sig bytea NOT NULL,
+ reserve_uuid bigint NOT NULL,
+ reserve_sig bytea NOT NULL,
+ execution_date bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ CONSTRAINT reserves_out_h_blind_ev_check CHECK ((length(h_blind_ev) = 64)),
+ CONSTRAINT reserves_out_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.reserves_out ATTACH PARTITION public.reserves_out_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: reserves_out_reserve_out_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+--
+
+ALTER TABLE public.reserves_out ALTER COLUMN reserve_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.reserves_out_reserve_out_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: reserves_reserve_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: reserves_reserve_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.reserves_reserve_uuid_seq OWNED BY public.reserves.reserve_uuid;
+ALTER TABLE public.reserves ALTER COLUMN reserve_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.reserves_reserve_uuid_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
@@ -3633,19 +10412,14 @@ COMMENT ON COLUMN public.revolving_work_shards.job_name IS 'unique name of the j
-- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.revolving_work_shards_shard_serial_id_seq
+ALTER TABLE public.revolving_work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.revolving_work_shards_shard_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
-
-
---
--- Name: revolving_work_shards_shard_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
---
-
-ALTER SEQUENCE public.revolving_work_shards_shard_serial_id_seq OWNED BY public.revolving_work_shards.shard_serial_id;
+ CACHE 1
+);
--
@@ -3664,721 +10438,935 @@ CREATE TABLE public.signkey_revocations (
-- Name: TABLE signkey_revocations; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.signkey_revocations IS 'remembering which online signing keys have been revoked';
+COMMENT ON TABLE public.signkey_revocations IS 'Table storing which online signing keys have been revoked';
--
-- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.signkey_revocations_signkey_revocations_serial_id_seq
+ALTER TABLE public.signkey_revocations ALTER COLUMN signkey_revocations_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.signkey_revocations_signkey_revocations_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: signkey_revocations_signkey_revocations_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: wad_in_entries; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.signkey_revocations_signkey_revocations_serial_id_seq OWNED BY public.signkey_revocations.signkey_revocations_serial_id;
+CREATE TABLE public.wad_in_entries (
+ wad_in_entry_serial_id bigint NOT NULL,
+ wad_in_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ h_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ deposit_fees_val bigint NOT NULL,
+ deposit_fees_frac integer NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT wad_in_entries_h_contract_check CHECK ((length(h_contract) = 64)),
+ CONSTRAINT wad_in_entries_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT wad_in_entries_purse_sig_check CHECK ((length(purse_sig) = 64)),
+ CONSTRAINT wad_in_entries_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT wad_in_entries_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+)
+PARTITION BY HASH (purse_pub);
--
--- Name: wire_accounts; Type: TABLE; Schema: public; Owner: -
+-- Name: TABLE wad_in_entries; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_accounts (
- payto_uri character varying NOT NULL,
- master_sig bytea,
- is_active boolean NOT NULL,
- last_change bigint NOT NULL,
- CONSTRAINT wire_accounts_master_sig_check CHECK ((length(master_sig) = 64))
-);
+COMMENT ON TABLE public.wad_in_entries IS 'list of purses aggregated in a wad according to the sending exchange';
--
--- Name: TABLE wire_accounts; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.wad_in_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.wire_accounts IS 'Table with current and historic bank accounts of the exchange. Entries never expire as we need to remember the last_change column indefinitely.';
+COMMENT ON COLUMN public.wad_in_entries.wad_in_serial_id IS 'wad for which the given purse was included in the aggregation';
--
--- Name: COLUMN wire_accounts.payto_uri; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.reserve_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_accounts.payto_uri IS 'payto URI (RFC 8905) with the bank account of the exchange.';
+COMMENT ON COLUMN public.wad_in_entries.reserve_pub IS 'target account of the purse (must be at the local exchange)';
--
--- Name: COLUMN wire_accounts.master_sig; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.purse_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_accounts.master_sig IS 'Signature of purpose TALER_SIGNATURE_MASTER_WIRE_DETAILS';
+COMMENT ON COLUMN public.wad_in_entries.purse_pub IS 'public key of the purse that was merged';
--
--- Name: COLUMN wire_accounts.is_active; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.h_contract; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_accounts.is_active IS 'true if we are currently supporting the use of this account.';
+COMMENT ON COLUMN public.wad_in_entries.h_contract IS 'hash of the contract terms of the purse';
--
--- Name: COLUMN wire_accounts.last_change; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.purse_expiration; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_accounts.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
+COMMENT ON COLUMN public.wad_in_entries.purse_expiration IS 'Time when the purse was set to expire';
--
--- Name: wire_auditor_account_progress; Type: TABLE; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.merge_timestamp; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_auditor_account_progress (
- master_pub bytea NOT NULL,
- account_name text NOT NULL,
- last_wire_reserve_in_serial_id bigint DEFAULT 0 NOT NULL,
- last_wire_wire_out_serial_id bigint DEFAULT 0 NOT NULL,
- wire_in_off bigint NOT NULL,
- wire_out_off bigint NOT NULL
-);
+COMMENT ON COLUMN public.wad_in_entries.merge_timestamp IS 'Time when the merge was approved';
--
--- Name: TABLE wire_auditor_account_progress; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.amount_with_fee_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.wire_auditor_account_progress IS 'information as to which transactions the auditor has processed in the exchange database. Used for SELECTing the
- statements to process. The indices include the last serial ID from the respective tables that we have processed. Thus, we need to select those table entries that are strictly larger (and process in monotonically increasing order).';
+COMMENT ON COLUMN public.wad_in_entries.amount_with_fee_val IS 'Total amount in the purse';
--
--- Name: wire_auditor_progress; Type: TABLE; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.wad_fee_val; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_auditor_progress (
- master_pub bytea NOT NULL,
- last_timestamp bigint NOT NULL,
- last_reserve_close_uuid bigint NOT NULL
-);
+COMMENT ON COLUMN public.wad_in_entries.wad_fee_val IS 'Total wad fees paid by the purse';
--
--- Name: wire_fee; Type: TABLE; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.deposit_fees_val; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_fee (
- wire_fee_serial bigint NOT NULL,
- wire_method character varying NOT NULL,
- start_date bigint NOT NULL,
- end_date bigint NOT NULL,
- wire_fee_val bigint NOT NULL,
- wire_fee_frac integer NOT NULL,
- closing_fee_val bigint NOT NULL,
- closing_fee_frac integer NOT NULL,
- master_sig bytea NOT NULL,
- CONSTRAINT wire_fee_master_sig_check CHECK ((length(master_sig) = 64))
-);
+COMMENT ON COLUMN public.wad_in_entries.deposit_fees_val IS 'Total deposit fees paid when depositing coins into the purse';
--
--- Name: TABLE wire_fee; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.reserve_sig; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.wire_fee IS 'list of the wire fees of this exchange, by date';
+COMMENT ON COLUMN public.wad_in_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
--
--- Name: COLUMN wire_fee.wire_fee_serial; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_in_entries.purse_sig; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_fee.wire_fee_serial IS 'needed for exchange-auditor replication logic';
+COMMENT ON COLUMN public.wad_in_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
--
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: wad_in_entries_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.wad_in_entries_default (
+ wad_in_entry_serial_id bigint NOT NULL,
+ wad_in_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ h_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ deposit_fees_val bigint NOT NULL,
+ deposit_fees_frac integer NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT wad_in_entries_h_contract_check CHECK ((length(h_contract) = 64)),
+ CONSTRAINT wad_in_entries_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT wad_in_entries_purse_sig_check CHECK ((length(purse_sig) = 64)),
+ CONSTRAINT wad_in_entries_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT wad_in_entries_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.wad_in_entries ATTACH PARTITION public.wad_in_entries_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: wad_in_entries_wad_in_entry_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.wire_fee_wire_fee_serial_seq
+ALTER TABLE public.wad_in_entries ALTER COLUMN wad_in_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wad_in_entries_wad_in_entry_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: wad_out_entries; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.wire_fee_wire_fee_serial_seq OWNED BY public.wire_fee.wire_fee_serial;
+CREATE TABLE public.wad_out_entries (
+ wad_out_entry_serial_id bigint NOT NULL,
+ wad_out_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ h_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ deposit_fees_val bigint NOT NULL,
+ deposit_fees_frac integer NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT wad_out_entries_h_contract_check CHECK ((length(h_contract) = 64)),
+ CONSTRAINT wad_out_entries_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT wad_out_entries_purse_sig_check CHECK ((length(purse_sig) = 64)),
+ CONSTRAINT wad_out_entries_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT wad_out_entries_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+)
+PARTITION BY HASH (purse_pub);
--
--- Name: wire_out; Type: TABLE; Schema: public; Owner: -
+-- Name: TABLE wad_out_entries; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_out (
- wireout_uuid bigint NOT NULL,
- execution_date bigint NOT NULL,
- wtid_raw bytea NOT NULL,
- wire_target_serial_id bigint NOT NULL,
- exchange_account_section text NOT NULL,
- amount_val bigint NOT NULL,
- amount_frac integer NOT NULL,
- CONSTRAINT wire_out_wtid_raw_check CHECK ((length(wtid_raw) = 32))
-);
+COMMENT ON TABLE public.wad_out_entries IS 'Purses combined into a wad';
--
--- Name: TABLE wire_out; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.wad_out_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.wire_out IS 'wire transfers the exchange has executed';
+COMMENT ON COLUMN public.wad_out_entries.wad_out_serial_id IS 'Wad the purse was part of';
--
--- Name: COLUMN wire_out.wire_target_serial_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.reserve_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_out.wire_target_serial_id IS 'Identifies the credited bank account and KYC status';
+COMMENT ON COLUMN public.wad_out_entries.reserve_pub IS 'Target reserve for the purse';
--
--- Name: COLUMN wire_out.exchange_account_section; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.purse_pub; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_out.exchange_account_section IS 'identifies the configuration section with the debit account of this payment';
+COMMENT ON COLUMN public.wad_out_entries.purse_pub IS 'Public key of the purse';
--
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.h_contract; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.wire_out_wireout_uuid_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON COLUMN public.wad_out_entries.h_contract IS 'Hash of the contract associated with the purse';
--
--- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.purse_expiration; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.wire_out_wireout_uuid_seq OWNED BY public.wire_out.wireout_uuid;
+COMMENT ON COLUMN public.wad_out_entries.purse_expiration IS 'Time when the purse expires';
--
--- Name: wire_targets; Type: TABLE; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.merge_timestamp; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.wire_targets (
- wire_target_serial_id bigint NOT NULL,
- h_payto bytea NOT NULL,
- payto_uri character varying NOT NULL,
- kyc_ok boolean DEFAULT false NOT NULL,
- external_id character varying,
- CONSTRAINT wire_targets_h_payto_check CHECK ((length(h_payto) = 64))
-);
+COMMENT ON COLUMN public.wad_out_entries.merge_timestamp IS 'Time when the merge was approved';
--
--- Name: TABLE wire_targets; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.amount_with_fee_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.wire_targets IS 'All recipients of money via the exchange';
+COMMENT ON COLUMN public.wad_out_entries.amount_with_fee_val IS 'Total amount in the purse';
--
--- Name: COLUMN wire_targets.h_payto; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.wad_fee_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_targets.h_payto IS 'Unsalted hash of payto_uri';
+COMMENT ON COLUMN public.wad_out_entries.wad_fee_val IS 'Wat fee charged to the purse';
--
--- Name: COLUMN wire_targets.payto_uri; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.deposit_fees_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_targets.payto_uri IS 'Can be a regular bank account, or also be a URI identifying a reserve-account (for P2P payments)';
+COMMENT ON COLUMN public.wad_out_entries.deposit_fees_val IS 'Total deposit fees charged to the purse';
--
--- Name: COLUMN wire_targets.kyc_ok; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.reserve_sig; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_targets.kyc_ok IS 'true if the KYC check was passed successfully';
+COMMENT ON COLUMN public.wad_out_entries.reserve_sig IS 'Signature by the receiving reserve, of purpose TALER_SIGNATURE_ACCOUNT_MERGE';
--
--- Name: COLUMN wire_targets.external_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wad_out_entries.purse_sig; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.wire_targets.external_id IS 'Name of the user that was used for OAuth 2.0-based legitimization';
+COMMENT ON COLUMN public.wad_out_entries.purse_sig IS 'Signature by the purse of purpose TALER_SIGNATURE_PURSE_MERGE';
--
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: wad_out_entries_default; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.wad_out_entries_default (
+ wad_out_entry_serial_id bigint NOT NULL,
+ wad_out_serial_id bigint,
+ reserve_pub bytea NOT NULL,
+ purse_pub bytea NOT NULL,
+ h_contract bytea NOT NULL,
+ purse_expiration bigint NOT NULL,
+ merge_timestamp bigint NOT NULL,
+ amount_with_fee_val bigint NOT NULL,
+ amount_with_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ deposit_fees_val bigint NOT NULL,
+ deposit_fees_frac integer NOT NULL,
+ reserve_sig bytea NOT NULL,
+ purse_sig bytea NOT NULL,
+ CONSTRAINT wad_out_entries_h_contract_check CHECK ((length(h_contract) = 64)),
+ CONSTRAINT wad_out_entries_purse_pub_check CHECK ((length(purse_pub) = 32)),
+ CONSTRAINT wad_out_entries_purse_sig_check CHECK ((length(purse_sig) = 64)),
+ CONSTRAINT wad_out_entries_reserve_pub_check CHECK ((length(reserve_pub) = 32)),
+ CONSTRAINT wad_out_entries_reserve_sig_check CHECK ((length(reserve_sig) = 64))
+);
+ALTER TABLE ONLY public.wad_out_entries ATTACH PARTITION public.wad_out_entries_default FOR VALUES WITH (modulus 1, remainder 0);
+
+
+--
+-- Name: wad_out_entries_wad_out_entry_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-CREATE SEQUENCE public.wire_targets_wire_target_serial_id_seq
+ALTER TABLE public.wad_out_entries ALTER COLUMN wad_out_entry_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wad_out_entries_wad_out_entry_serial_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
- CACHE 1;
+ CACHE 1
+);
--
--- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: wads_in; Type: TABLE; Schema: public; Owner: -
--
-ALTER SEQUENCE public.wire_targets_wire_target_serial_id_seq OWNED BY public.wire_targets.wire_target_serial_id;
+CREATE TABLE public.wads_in (
+ wad_in_serial_id bigint NOT NULL,
+ wad_id bytea NOT NULL,
+ origin_exchange_url text NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ arrival_time bigint NOT NULL,
+ CONSTRAINT wads_in_wad_id_check CHECK ((length(wad_id) = 24))
+)
+PARTITION BY HASH (wad_id);
--
--- Name: work_shards; Type: TABLE; Schema: public; Owner: -
+-- Name: TABLE wads_in; Type: COMMENT; Schema: public; Owner: -
--
-CREATE TABLE public.work_shards (
- shard_serial_id bigint NOT NULL,
- last_attempt bigint NOT NULL,
- start_row bigint NOT NULL,
- end_row bigint NOT NULL,
- completed boolean DEFAULT false NOT NULL,
- job_name character varying NOT NULL
-);
+COMMENT ON TABLE public.wads_in IS 'Incoming exchange-to-exchange wad wire transfers';
--
--- Name: TABLE work_shards; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wads_in.wad_id; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON TABLE public.work_shards IS 'coordinates work between multiple processes working on the same job';
+COMMENT ON COLUMN public.wads_in.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
--
--- Name: COLUMN work_shards.shard_serial_id; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wads_in.origin_exchange_url; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.shard_serial_id IS 'unique serial number identifying the shard';
+COMMENT ON COLUMN public.wads_in.origin_exchange_url IS 'Base URL of the originating URL, also part of the wire transfer subject';
--
--- Name: COLUMN work_shards.last_attempt; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wads_in.amount_val; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
+COMMENT ON COLUMN public.wads_in.amount_val IS 'Actual amount that was received by our exchange';
--
--- Name: COLUMN work_shards.start_row; Type: COMMENT; Schema: public; Owner: -
+-- Name: COLUMN wads_in.arrival_time; Type: COMMENT; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.start_row IS 'row at which the shard scope starts, inclusive';
+COMMENT ON COLUMN public.wads_in.arrival_time IS 'Time when the wad was received';
--
--- Name: COLUMN work_shards.end_row; Type: COMMENT; Schema: public; Owner: -
+-- Name: wads_in_default; Type: TABLE; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.end_row IS 'row at which the shard scope ends, exclusive';
+CREATE TABLE public.wads_in_default (
+ wad_in_serial_id bigint NOT NULL,
+ wad_id bytea NOT NULL,
+ origin_exchange_url text NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ arrival_time bigint NOT NULL,
+ CONSTRAINT wads_in_wad_id_check CHECK ((length(wad_id) = 24))
+);
+ALTER TABLE ONLY public.wads_in ATTACH PARTITION public.wads_in_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: COLUMN work_shards.completed; Type: COMMENT; Schema: public; Owner: -
+-- Name: wads_in_wad_in_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.completed IS 'set to TRUE once the shard is finished by a worker';
+ALTER TABLE public.wads_in ALTER COLUMN wad_in_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wads_in_wad_in_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
--- Name: COLUMN work_shards.job_name; Type: COMMENT; Schema: public; Owner: -
+-- Name: wads_out; Type: TABLE; Schema: public; Owner: -
--
-COMMENT ON COLUMN public.work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
+CREATE TABLE public.wads_out (
+ wad_out_serial_id bigint NOT NULL,
+ wad_id bytea NOT NULL,
+ partner_serial_id bigint NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ execution_time bigint NOT NULL,
+ CONSTRAINT wads_out_wad_id_check CHECK ((length(wad_id) = 24))
+)
+PARTITION BY HASH (wad_id);
--
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
+-- Name: TABLE wads_out; Type: COMMENT; Schema: public; Owner: -
--
-CREATE SEQUENCE public.work_shards_shard_serial_id_seq
- START WITH 1
- INCREMENT BY 1
- NO MINVALUE
- NO MAXVALUE
- CACHE 1;
+COMMENT ON TABLE public.wads_out IS 'Wire transfers made to another exchange to transfer purse funds';
--
--- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE OWNED BY; Schema: public; Owner: -
+-- Name: COLUMN wads_out.wad_id; Type: COMMENT; Schema: public; Owner: -
--
-ALTER SEQUENCE public.work_shards_shard_serial_id_seq OWNED BY public.work_shards.shard_serial_id;
+COMMENT ON COLUMN public.wads_out.wad_id IS 'Unique identifier of the wad, part of the wire transfer subject';
--
--- Name: aggregation_tracking aggregation_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wads_out.partner_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.aggregation_tracking ALTER COLUMN aggregation_serial_id SET DEFAULT nextval('public.aggregation_tracking_aggregation_serial_id_seq'::regclass);
+COMMENT ON COLUMN public.wads_out.partner_serial_id IS 'target exchange of the wad';
--
--- Name: app_bankaccount account_no; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wads_out.amount_val; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.app_bankaccount ALTER COLUMN account_no SET DEFAULT nextval('public.app_bankaccount_account_no_seq'::regclass);
+COMMENT ON COLUMN public.wads_out.amount_val IS 'Amount that was wired';
--
--- Name: app_banktransaction id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wads_out.execution_time; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.app_banktransaction ALTER COLUMN id SET DEFAULT nextval('public.app_banktransaction_id_seq'::regclass);
+COMMENT ON COLUMN public.wads_out.execution_time IS 'Time when the wire transfer was scheduled';
--
--- Name: auditor_denom_sigs auditor_denom_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wads_out_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auditor_denom_sigs ALTER COLUMN auditor_denom_serial SET DEFAULT nextval('public.auditor_denom_sigs_auditor_denom_serial_seq'::regclass);
+CREATE TABLE public.wads_out_default (
+ wad_out_serial_id bigint NOT NULL,
+ wad_id bytea NOT NULL,
+ partner_serial_id bigint NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ execution_time bigint NOT NULL,
+ CONSTRAINT wads_out_wad_id_check CHECK ((length(wad_id) = 24))
+);
+ALTER TABLE ONLY public.wads_out ATTACH PARTITION public.wads_out_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: auditor_reserves auditor_reserves_rowid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wads_out_wad_out_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auditor_reserves ALTER COLUMN auditor_reserves_rowid SET DEFAULT nextval('public.auditor_reserves_auditor_reserves_rowid_seq'::regclass);
+ALTER TABLE public.wads_out ALTER COLUMN wad_out_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wads_out_wad_out_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
--- Name: auditors auditor_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_accounts; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auditors ALTER COLUMN auditor_uuid SET DEFAULT nextval('public.auditors_auditor_uuid_seq'::regclass);
+CREATE TABLE public.wire_accounts (
+ payto_uri character varying NOT NULL,
+ master_sig bytea,
+ is_active boolean NOT NULL,
+ last_change bigint NOT NULL,
+ CONSTRAINT wire_accounts_master_sig_check CHECK ((length(master_sig) = 64))
+);
--
--- Name: auth_group id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: TABLE wire_accounts; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_group ALTER COLUMN id SET DEFAULT nextval('public.auth_group_id_seq'::regclass);
+COMMENT ON TABLE public.wire_accounts IS 'Table with current and historic bank accounts of the exchange. Entries never expire as we need to remember the last_change column indefinitely.';
--
--- Name: auth_group_permissions id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_accounts.payto_uri; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_group_permissions ALTER COLUMN id SET DEFAULT nextval('public.auth_group_permissions_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_accounts.payto_uri IS 'payto URI (RFC 8905) with the bank account of the exchange.';
--
--- Name: auth_permission id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_accounts.master_sig; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_permission ALTER COLUMN id SET DEFAULT nextval('public.auth_permission_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_accounts.master_sig IS 'Signature of purpose TALER_SIGNATURE_MASTER_WIRE_DETAILS';
--
--- Name: auth_user id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_accounts.is_active; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_user ALTER COLUMN id SET DEFAULT nextval('public.auth_user_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_accounts.is_active IS 'true if we are currently supporting the use of this account.';
--
--- Name: auth_user_groups id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_accounts.last_change; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_user_groups ALTER COLUMN id SET DEFAULT nextval('public.auth_user_groups_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_accounts.last_change IS 'Latest time when active status changed. Used to detect replays of old messages.';
--
--- Name: auth_user_user_permissions id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_auditor_account_progress; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.auth_user_user_permissions ALTER COLUMN id SET DEFAULT nextval('public.auth_user_user_permissions_id_seq'::regclass);
+CREATE TABLE public.wire_auditor_account_progress (
+ master_pub bytea NOT NULL,
+ account_name text NOT NULL,
+ last_wire_reserve_in_serial_id bigint DEFAULT 0 NOT NULL,
+ last_wire_wire_out_serial_id bigint DEFAULT 0 NOT NULL,
+ wire_in_off bigint NOT NULL,
+ wire_out_off bigint NOT NULL
+);
--
--- Name: denomination_revocations denom_revocations_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: TABLE wire_auditor_account_progress; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.denomination_revocations ALTER COLUMN denom_revocations_serial_id SET DEFAULT nextval('public.denomination_revocations_denom_revocations_serial_id_seq'::regclass);
+COMMENT ON TABLE public.wire_auditor_account_progress IS 'information as to which transactions the auditor has processed in the exchange database. Used for SELECTing the
+ statements to process. The indices include the last serial ID from the respective tables that we have processed. Thus, we need to select those table entries that are strictly larger (and process in monotonically increasing order).';
--
--- Name: denominations denominations_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_auditor_progress; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.denominations ALTER COLUMN denominations_serial SET DEFAULT nextval('public.denominations_denominations_serial_seq'::regclass);
+CREATE TABLE public.wire_auditor_progress (
+ master_pub bytea NOT NULL,
+ last_timestamp bigint NOT NULL,
+ last_reserve_close_uuid bigint NOT NULL
+);
--
--- Name: deposit_confirmations serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_fee; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.deposit_confirmations ALTER COLUMN serial_id SET DEFAULT nextval('public.deposit_confirmations_serial_id_seq'::regclass);
+CREATE TABLE public.wire_fee (
+ wire_fee_serial bigint NOT NULL,
+ wire_method character varying NOT NULL,
+ start_date bigint NOT NULL,
+ end_date bigint NOT NULL,
+ wire_fee_val bigint NOT NULL,
+ wire_fee_frac integer NOT NULL,
+ closing_fee_val bigint NOT NULL,
+ closing_fee_frac integer NOT NULL,
+ wad_fee_val bigint NOT NULL,
+ wad_fee_frac integer NOT NULL,
+ master_sig bytea NOT NULL,
+ CONSTRAINT wire_fee_master_sig_check CHECK ((length(master_sig) = 64))
+);
--
--- Name: deposits deposit_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: TABLE wire_fee; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.deposits ALTER COLUMN deposit_serial_id SET DEFAULT nextval('public.deposits_deposit_serial_id_seq'::regclass);
+COMMENT ON TABLE public.wire_fee IS 'list of the wire fees of this exchange, by date';
--
--- Name: django_content_type id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_fee.wire_fee_serial; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.django_content_type ALTER COLUMN id SET DEFAULT nextval('public.django_content_type_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_fee.wire_fee_serial IS 'needed for exchange-auditor replication logic';
--
--- Name: django_migrations id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_fee_wire_fee_serial_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.django_migrations ALTER COLUMN id SET DEFAULT nextval('public.django_migrations_id_seq'::regclass);
+ALTER TABLE public.wire_fee ALTER COLUMN wire_fee_serial ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wire_fee_wire_fee_serial_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
+
+
+--
+-- Name: wire_out; Type: TABLE; Schema: public; Owner: -
+--
+
+CREATE TABLE public.wire_out (
+ wireout_uuid bigint NOT NULL,
+ execution_date bigint NOT NULL,
+ wtid_raw bytea NOT NULL,
+ wire_target_h_payto bytea,
+ exchange_account_section text NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ CONSTRAINT wire_out_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
+ CONSTRAINT wire_out_wtid_raw_check CHECK ((length(wtid_raw) = 32))
+)
+PARTITION BY HASH (wtid_raw);
+
+
+--
+-- Name: TABLE wire_out; Type: COMMENT; Schema: public; Owner: -
+--
+
+COMMENT ON TABLE public.wire_out IS 'wire transfers the exchange has executed';
--
--- Name: exchange_sign_keys esk_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_out.wire_target_h_payto; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.exchange_sign_keys ALTER COLUMN esk_serial SET DEFAULT nextval('public.exchange_sign_keys_esk_serial_seq'::regclass);
+COMMENT ON COLUMN public.wire_out.wire_target_h_payto IS 'Identifies the credited bank account and KYC status';
--
--- Name: extension_details extension_details_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_out.exchange_account_section; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.extension_details ALTER COLUMN extension_details_serial_id SET DEFAULT nextval('public.extension_details_extension_details_serial_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_out.exchange_account_section IS 'identifies the configuration section with the debit account of this payment';
--
--- Name: known_coins known_coin_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_out_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.known_coins ALTER COLUMN known_coin_id SET DEFAULT nextval('public.known_coins_known_coin_id_seq'::regclass);
+CREATE TABLE public.wire_out_default (
+ wireout_uuid bigint NOT NULL,
+ execution_date bigint NOT NULL,
+ wtid_raw bytea NOT NULL,
+ wire_target_h_payto bytea,
+ exchange_account_section text NOT NULL,
+ amount_val bigint NOT NULL,
+ amount_frac integer NOT NULL,
+ CONSTRAINT wire_out_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32)),
+ CONSTRAINT wire_out_wtid_raw_check CHECK ((length(wtid_raw) = 32))
+);
+ALTER TABLE ONLY public.wire_out ATTACH PARTITION public.wire_out_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: merchant_accounts account_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_out_wireout_uuid_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_accounts ALTER COLUMN account_serial SET DEFAULT nextval('public.merchant_accounts_account_serial_seq'::regclass);
+ALTER TABLE public.wire_out ALTER COLUMN wireout_uuid ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wire_out_wireout_uuid_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
--- Name: merchant_deposits deposit_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_targets; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_deposits ALTER COLUMN deposit_serial SET DEFAULT nextval('public.merchant_deposits_deposit_serial_seq'::regclass);
+CREATE TABLE public.wire_targets (
+ wire_target_serial_id bigint NOT NULL,
+ wire_target_h_payto bytea NOT NULL,
+ payto_uri character varying NOT NULL,
+ kyc_ok boolean DEFAULT false NOT NULL,
+ external_id character varying,
+ CONSTRAINT wire_targets_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32))
+)
+PARTITION BY HASH (wire_target_h_payto);
--
--- Name: merchant_exchange_signing_keys signkey_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: TABLE wire_targets; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_exchange_signing_keys ALTER COLUMN signkey_serial SET DEFAULT nextval('public.merchant_exchange_signing_keys_signkey_serial_seq'::regclass);
+COMMENT ON TABLE public.wire_targets IS 'All senders and recipients of money via the exchange';
--
--- Name: merchant_exchange_wire_fees wirefee_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_targets.wire_target_h_payto; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_exchange_wire_fees ALTER COLUMN wirefee_serial SET DEFAULT nextval('public.merchant_exchange_wire_fees_wirefee_serial_seq'::regclass);
+COMMENT ON COLUMN public.wire_targets.wire_target_h_payto IS 'Unsalted hash of payto_uri';
--
--- Name: merchant_instances merchant_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_targets.payto_uri; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_instances ALTER COLUMN merchant_serial SET DEFAULT nextval('public.merchant_instances_merchant_serial_seq'::regclass);
+COMMENT ON COLUMN public.wire_targets.payto_uri IS 'Can be a regular bank account, or also be a URI identifying a reserve-account (for P2P payments)';
--
--- Name: merchant_inventory product_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_targets.kyc_ok; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_inventory ALTER COLUMN product_serial SET DEFAULT nextval('public.merchant_inventory_product_serial_seq'::regclass);
+COMMENT ON COLUMN public.wire_targets.kyc_ok IS 'true if the KYC check was passed successfully';
--
--- Name: merchant_kyc kyc_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN wire_targets.external_id; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_kyc ALTER COLUMN kyc_serial_id SET DEFAULT nextval('public.merchant_kyc_kyc_serial_id_seq'::regclass);
+COMMENT ON COLUMN public.wire_targets.external_id IS 'Name of the user that was used for OAuth 2.0-based legitimization';
--
--- Name: merchant_orders order_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_targets_default; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_orders ALTER COLUMN order_serial SET DEFAULT nextval('public.merchant_orders_order_serial_seq'::regclass);
+CREATE TABLE public.wire_targets_default (
+ wire_target_serial_id bigint NOT NULL,
+ wire_target_h_payto bytea NOT NULL,
+ payto_uri character varying NOT NULL,
+ kyc_ok boolean DEFAULT false NOT NULL,
+ external_id character varying,
+ CONSTRAINT wire_targets_wire_target_h_payto_check CHECK ((length(wire_target_h_payto) = 32))
+);
+ALTER TABLE ONLY public.wire_targets ATTACH PARTITION public.wire_targets_default FOR VALUES WITH (modulus 1, remainder 0);
--
--- Name: merchant_refunds refund_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: wire_targets_wire_target_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_refunds ALTER COLUMN refund_serial SET DEFAULT nextval('public.merchant_refunds_refund_serial_seq'::regclass);
+ALTER TABLE public.wire_targets ALTER COLUMN wire_target_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.wire_targets_wire_target_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
--- Name: merchant_tip_pickups pickup_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: work_shards; Type: TABLE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_tip_pickups ALTER COLUMN pickup_serial SET DEFAULT nextval('public.merchant_tip_pickups_pickup_serial_seq'::regclass);
+CREATE TABLE public.work_shards (
+ shard_serial_id bigint NOT NULL,
+ last_attempt bigint NOT NULL,
+ start_row bigint NOT NULL,
+ end_row bigint NOT NULL,
+ completed boolean DEFAULT false NOT NULL,
+ job_name character varying NOT NULL
+);
--
--- Name: merchant_tip_reserves reserve_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: TABLE work_shards; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_tip_reserves ALTER COLUMN reserve_serial SET DEFAULT nextval('public.merchant_tip_reserves_reserve_serial_seq'::regclass);
+COMMENT ON TABLE public.work_shards IS 'coordinates work between multiple processes working on the same job';
--
--- Name: merchant_tips tip_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.shard_serial_id; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_tips ALTER COLUMN tip_serial SET DEFAULT nextval('public.merchant_tips_tip_serial_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.shard_serial_id IS 'unique serial number identifying the shard';
--
--- Name: merchant_transfers credit_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.last_attempt; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.merchant_transfers ALTER COLUMN credit_serial SET DEFAULT nextval('public.merchant_transfers_credit_serial_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.last_attempt IS 'last time a worker attempted to work on the shard';
--
--- Name: prewire prewire_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.start_row; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.prewire ALTER COLUMN prewire_uuid SET DEFAULT nextval('public.prewire_prewire_uuid_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.start_row IS 'row at which the shard scope starts, inclusive';
--
--- Name: recoup recoup_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.end_row; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.recoup ALTER COLUMN recoup_uuid SET DEFAULT nextval('public.recoup_recoup_uuid_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.end_row IS 'row at which the shard scope ends, exclusive';
--
--- Name: recoup_refresh recoup_refresh_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.completed; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.recoup_refresh ALTER COLUMN recoup_refresh_uuid SET DEFAULT nextval('public.recoup_refresh_recoup_refresh_uuid_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.completed IS 'set to TRUE once the shard is finished by a worker';
--
--- Name: refresh_commitments melt_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: COLUMN work_shards.job_name; Type: COMMENT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.refresh_commitments ALTER COLUMN melt_serial_id SET DEFAULT nextval('public.refresh_commitments_melt_serial_id_seq'::regclass);
+COMMENT ON COLUMN public.work_shards.job_name IS 'unique name of the job the workers on this shard are performing';
--
--- Name: refresh_revealed_coins rrc_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: work_shards_shard_serial_id_seq; Type: SEQUENCE; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.refresh_revealed_coins ALTER COLUMN rrc_serial SET DEFAULT nextval('public.refresh_revealed_coins_rrc_serial_seq'::regclass);
+ALTER TABLE public.work_shards ALTER COLUMN shard_serial_id ADD GENERATED BY DEFAULT AS IDENTITY (
+ SEQUENCE NAME public.work_shards_shard_serial_id_seq
+ START WITH 1
+ INCREMENT BY 1
+ NO MINVALUE
+ NO MAXVALUE
+ CACHE 1
+);
--
--- Name: refresh_transfer_keys rtc_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: app_bankaccount account_no; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.refresh_transfer_keys ALTER COLUMN rtc_serial SET DEFAULT nextval('public.refresh_transfer_keys_rtc_serial_seq'::regclass);
+ALTER TABLE ONLY public.app_bankaccount ALTER COLUMN account_no SET DEFAULT nextval('public.app_bankaccount_account_no_seq'::regclass);
--
--- Name: refunds refund_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: app_banktransaction id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.refunds ALTER COLUMN refund_serial_id SET DEFAULT nextval('public.refunds_refund_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.app_banktransaction ALTER COLUMN id SET DEFAULT nextval('public.app_banktransaction_id_seq'::regclass);
--
--- Name: reserves reserve_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auditor_reserves auditor_reserves_rowid; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.reserves ALTER COLUMN reserve_uuid SET DEFAULT nextval('public.reserves_reserve_uuid_seq'::regclass);
+ALTER TABLE ONLY public.auditor_reserves ALTER COLUMN auditor_reserves_rowid SET DEFAULT nextval('public.auditor_reserves_auditor_reserves_rowid_seq'::regclass);
--
--- Name: reserves_close close_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_group id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.reserves_close ALTER COLUMN close_uuid SET DEFAULT nextval('public.reserves_close_close_uuid_seq'::regclass);
+ALTER TABLE ONLY public.auth_group ALTER COLUMN id SET DEFAULT nextval('public.auth_group_id_seq'::regclass);
--
--- Name: reserves_in reserve_in_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_group_permissions id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.reserves_in ALTER COLUMN reserve_in_serial_id SET DEFAULT nextval('public.reserves_in_reserve_in_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.auth_group_permissions ALTER COLUMN id SET DEFAULT nextval('public.auth_group_permissions_id_seq'::regclass);
--
--- Name: reserves_out reserve_out_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_permission id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.reserves_out ALTER COLUMN reserve_out_serial_id SET DEFAULT nextval('public.reserves_out_reserve_out_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.auth_permission ALTER COLUMN id SET DEFAULT nextval('public.auth_permission_id_seq'::regclass);
--
--- Name: revolving_work_shards shard_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_user id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.revolving_work_shards ALTER COLUMN shard_serial_id SET DEFAULT nextval('public.revolving_work_shards_shard_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.auth_user ALTER COLUMN id SET DEFAULT nextval('public.auth_user_id_seq'::regclass);
--
--- Name: signkey_revocations signkey_revocations_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_user_groups id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.signkey_revocations ALTER COLUMN signkey_revocations_serial_id SET DEFAULT nextval('public.signkey_revocations_signkey_revocations_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.auth_user_groups ALTER COLUMN id SET DEFAULT nextval('public.auth_user_groups_id_seq'::regclass);
--
--- Name: wire_fee wire_fee_serial; Type: DEFAULT; Schema: public; Owner: -
+-- Name: auth_user_user_permissions id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.wire_fee ALTER COLUMN wire_fee_serial SET DEFAULT nextval('public.wire_fee_wire_fee_serial_seq'::regclass);
+ALTER TABLE ONLY public.auth_user_user_permissions ALTER COLUMN id SET DEFAULT nextval('public.auth_user_user_permissions_id_seq'::regclass);
--
--- Name: wire_out wireout_uuid; Type: DEFAULT; Schema: public; Owner: -
+-- Name: deposit_confirmations serial_id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.wire_out ALTER COLUMN wireout_uuid SET DEFAULT nextval('public.wire_out_wireout_uuid_seq'::regclass);
+ALTER TABLE ONLY public.deposit_confirmations ALTER COLUMN serial_id SET DEFAULT nextval('public.deposit_confirmations_serial_id_seq'::regclass);
--
--- Name: wire_targets wire_target_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: django_content_type id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.wire_targets ALTER COLUMN wire_target_serial_id SET DEFAULT nextval('public.wire_targets_wire_target_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.django_content_type ALTER COLUMN id SET DEFAULT nextval('public.django_content_type_id_seq'::regclass);
--
--- Name: work_shards shard_serial_id; Type: DEFAULT; Schema: public; Owner: -
+-- Name: django_migrations id; Type: DEFAULT; Schema: public; Owner: -
--
-ALTER TABLE ONLY public.work_shards ALTER COLUMN shard_serial_id SET DEFAULT nextval('public.work_shards_shard_serial_id_seq'::regclass);
+ALTER TABLE ONLY public.django_migrations ALTER COLUMN id SET DEFAULT nextval('public.django_migrations_id_seq'::regclass);
--
@@ -4386,19 +11374,34 @@ ALTER TABLE ONLY public.work_shards ALTER COLUMN shard_serial_id SET DEFAULT nex
--
COPY _v.patches (patch_name, applied_tsz, applied_by, requires, conflicts) FROM stdin;
-exchange-0001 2021-12-01 12:08:26.821188+01 dold {} {}
-merchant-0001 2021-12-01 12:08:27.343817+01 dold {} {}
-merchant-0002 2021-12-01 12:08:27.641319+01 dold {} {}
-merchant-0003 2021-12-01 12:08:27.652283+01 dold {} {}
-auditor-0001 2021-12-01 12:08:27.68794+01 dold {} {}
+exchange-0001 2022-06-19 14:06:05.845802+02 grothoff {} {}
+merchant-0001 2022-06-19 14:06:06.801597+02 grothoff {} {}
+merchant-0002 2022-06-19 14:06:07.218735+02 grothoff {} {}
+auditor-0001 2022-06-19 14:06:07.360062+02 grothoff {} {}
\.
--
--- Data for Name: aggregation_tracking; Type: TABLE DATA; Schema: public; Owner: -
+-- Data for Name: account_merges_default; Type: TABLE DATA; Schema: public; Owner: -
--
-COPY public.aggregation_tracking (aggregation_serial_id, deposit_serial_id, wtid_raw) FROM stdin;
+COPY public.account_merges_default (account_merge_request_serial_id, reserve_pub, reserve_sig, purse_pub) FROM stdin;
+\.
+
+
+--
+-- Data for Name: aggregation_tracking_default; Type: TABLE DATA; Schema: public; Owner: -
+--
+
+COPY public.aggregation_tracking_default (aggregation_serial_id, deposit_serial_id, wtid_raw) FROM stdin;
+\.
+
+
+--
+-- Data for Name: aggregation_transient_default; Type: TABLE DATA; Schema: public; Owner: -
+--
+
+COPY public.aggregation_transient_default (amount_val, amount_frac, wire_target_h_payto, exchange_account_section, wtid_raw) FROM stdin;
\.
@@ -4428,10 +11431,10 @@ t 2 +TESTKUDOS:28 2
--
COPY public.app_banktransaction (id, amount, subject, date, cancelled, request_uid, credit_account_id, debit_account_id) FROM stdin;
-1 TESTKUDOS:100 Joining bonus 2021-12-01 12:08:37.853361+01 f fa27c9fd-6b8a-4a73-a420-a9c20c435f87 12 1
-2 TESTKUDOS:10 89JVAQPM740BFC7Q5NP3BGAK1J9ASAG4CCPET13JTSSP7JX9A8K0 2021-12-01 12:08:41.746972+01 f 32ad7113-0fe5-4322-9976-29146fe0caeb 2 12
-3 TESTKUDOS:100 Joining bonus 2021-12-01 12:08:50.064111+01 f 5b41a1eb-e222-4563-985b-534f758db2df 13 1
-4 TESTKUDOS:18 00TNSQS28VF2P5ACGRFV5TGYWBH5S7554T15VC9X0WZHVT0K2NH0 2021-12-01 12:08:50.762479+01 f 102e985e-f7de-4a68-8d06-dbee971e04a2 2 13
+1 TESTKUDOS:100 Joining bonus 2022-06-19 14:06:17.194631+02 f a43af79c-fad5-401b-889a-a363e36aecac 12 1
+2 TESTKUDOS:10 HRGRTQAX05S2Q8P881TJS82Q05PSXSVZJ7686REZX4YK5R47Q1WG 2022-06-19 14:06:20.752813+02 f 7668adf5-d217-422d-92ef-cd569f8018db 2 12
+3 TESTKUDOS:100 Joining bonus 2022-06-19 14:06:27.794023+02 f cadcef48-6d5f-41db-8c31-a09a40d9f932 13 1
+4 TESTKUDOS:18 1DCW1ACQCWXY35T5PQV1FAB1WJDPJE4AHWQQEKGNE8KQ151K4FEG 2022-06-19 14:06:28.454299+02 f 16cddff4-1bc6-439e-97a2-70fab6ee18d2 2 13
\.
@@ -4440,8 +11443,8 @@ COPY public.app_banktransaction (id, amount, subject, date, cancelled, request_u
--
COPY public.app_talerwithdrawoperation (withdraw_id, amount, selection_done, confirmation_done, aborted, selected_reserve_pub, selected_exchange_account_id, withdraw_account_id) FROM stdin;
-7c639153-d45e-46b5-9212-411a0a5f871a TESTKUDOS:10 t t f 89JVAQPM740BFC7Q5NP3BGAK1J9ASAG4CCPET13JTSSP7JX9A8K0 2 12
-e3a4ee21-ea44-47ee-a1f4-34dc4be04713 TESTKUDOS:18 t t f 00TNSQS28VF2P5ACGRFV5TGYWBH5S7554T15VC9X0WZHVT0K2NH0 2 13
+1c75882b-64a2-4661-ab39-e41a51ffc059 TESTKUDOS:10 t t f HRGRTQAX05S2Q8P881TJS82Q05PSXSVZJ7686REZX4YK5R47Q1WG 2 12
+bb82dbb8-93ba-40ed-9f04-74d93682aacc TESTKUDOS:18 t t f 1DCW1ACQCWXY35T5PQV1FAB1WJDPJE4AHWQQEKGNE8KQ151K4FEG 2 13
\.
@@ -4458,430 +11461,430 @@ COPY public.auditor_balance_summary (master_pub, denom_balance_val, denom_balanc
--
COPY public.auditor_denom_sigs (auditor_denom_serial, auditor_uuid, denominations_serial, auditor_sig) FROM stdin;
-1 1 46 \\xc074de874a97e6da510f44a63fe43eef7bd3bb9284a1d29fbf346b052cb427f0d481e20a3a7a3447165db06fb5ddfae0df484593bdd18bc0192aaf5dcca9e006
-2 1 147 \\x9955203a82842400bc2b2431db96920bede1a4e42f96fe0aa0077fbcf5284e9709f6395a65fcac94f65d38dfcb02f968c27b674fd164e873979d437fc7eaf70e
-3 1 395 \\x88bb1ebc61ec29f15e6dea9ffa8a2cb4d626ec39ba5b838e449253907a0c5bd5e6acf460fa0fd0390b67ec87693740399bb372ec37218ae6833f954f82a59805
-4 1 197 \\x4bb239d99e9fa6e4cca9f1ab4bad03de98df4348f902046f617c7460cfad06e380f36d470524f622f2af81a36a219ce2a32865371d94758d2efba279a63bcf0f
-5 1 261 \\x501aaa0141c97a475743d5816c612ce8f659379ef88f628b9ad4e598e8a766fe4df1ccef00f4ca1fc537b29ebb14607f2e689e87e8eb54a735345317b8936909
-6 1 381 \\xd60ec734452b90329c7e94e7029f4565f9203f7bb5a552c7e42bc8d850191a24bfaeb04c4e5c236a07fa8336f58bde8ea82621aee8ad66b77e718b5b41482107
-7 1 146 \\x7489dd2f83bf9da47242ba192a1657cd712e645832e295759baa6d1979d0bb31a4a1c910791b2ef56b2397d1bfe652dbe7c96da6cdc61eba7ee37a33899cd10a
-8 1 231 \\x33b481db54d2d5aa78f476af43f73e0ccf52f55f333a9657cc1f042bd48888fb4675c64a430c3e1b54bf360c854d5c174573f4480bac61b0bb832be8baa2d408
-9 1 144 \\x32e07c7148371d65d6d1525c86fecb5bb0f55d2f096af56e3dd5b094e1e76e30d8ff9436fe0ffbab946de1e99b01f9fe80361b506cf096e73ed3f107c97be50b
-10 1 169 \\xbb0fcbd24fc7ab97d60b463031d566719691011d3d7ce509c51567a9b02568245688b89d84c91496c2c968ae5dd6fc7e96f0feef3eeef8c34a3e6cae0f8c270b
-11 1 380 \\x435301bcfaf676b8adffb60f0a66024f364ecf14e94d4401841972e1813c78394f7b73270bdff378d9f8a1bb807f946870de58123461098418ec864c4f5bde0e
-12 1 80 \\x93556403518c6e7926d644bacca6b437b5ba7c5477d1f6540ee1648efc28e6159a768a0b63ae1161b50956362a1170e6da9dafa5ec5317d087db39bab2283b05
-13 1 362 \\x8adcc6dadc800a47937e520e73bcfc427f4692cc8684058649c26b68422b2b71b9424f4e6b735704fe2a850af1724e2361123a7bdb0b6d2ca1e5aeccfafbd50e
-14 1 34 \\x9d7d50110d3167ceb621b653f9176e1be868bf97d8cd1de59d23623bc32dcaed664a3ba42b62e3017442a942f9fd282e1471fab3de1c6dc4810e6bf16d38f706
-15 1 39 \\xc20374f718f2b2dd838b5efba84a9b316d43d5aecdfbf95e94064e865feaad8bf1895d303601c2d42d56c75b5b53bfa72c5dfff80b377009d01393eeaca16b01
-16 1 355 \\x6a399968fd73c99471b14a50758af77fefb31e84770ccfa522f82d9ad4c81304ae4e504e531236d416392d547fed648d273f7ae94d2b4584b54e1ba53a727601
-17 1 348 \\xbb919777498f3150f30c93f38dad4fdb85b99542344385a594eee2f32581c2eb95d6c2b3e85894bb7195978c1090d1fb099ae4d7e0fa414ab4f40b5eb70d4b00
-18 1 242 \\x51566f0ae4aaacfa92ae4c9a6048fa1e6e1fbaff187f86ed43334c0a869e9776a4efe4014c4aaf5787f366b1d21ed695e5fbb9ef01c3a4edbc630578edf88801
-19 1 213 \\x860a9ebbfc3b289055c7d8124ca46fb012537b4fa5a4078813be6026adbf350d10e68b64a81d7bf783679bfdcbf8ec60015a847f2957602eabae3859468b9704
-20 1 243 \\x438ff81f5f803edf9e5ce34f3ce0fe3a0ed3f1fe0512fab7f0861f2dc57688a59125784e363e50a7a6d796604b7baf4d3ce7190a182051ded35c24917aca2808
-21 1 264 \\x80b132395f5696342c33da67d7975b66fb8bb6e8fa4ce3bf2b69eec790e1bbe7aa8b6eef1c6b57e7f830efcabfe650f325bfc1c344fcf41b4aca247698c5900e
-22 1 153 \\x65c5471413fd8fbdc53e24a40eb378fedfbb61ce32f7a641862258dcabdfa0546846fc001823d794e07132086853d70c5507c2c5adbc2b7dced59f977355b709
-23 1 382 \\xcd15a147cef28c86f9a2e25174b32442e0ab6dccde2d34f58efa9c5ff6068bc23758b2aba2db12f62d1a3dbb1b648b07e11c1952d0c8a8b3177ecbd7364eca0f
-24 1 389 \\x9a5cba279ff4107f52e63ca7c0329b6437ced5d09510963b0bc4287e3eae4c5fff69fb1708bd3b33c859ec026d9d6f6ea36387a7683d5aef79eeb107e7b8450e
-25 1 68 \\xd775307eaad78ea6f87fb87871ea9baf60371eefa8950c07431aea543e9a6f0b3af29cc679eac07e23307f5d35ef145de568262c7dcb6e502a826fe4f1873c05
-26 1 5 \\xc37086f7f3838fb295f7a40e12b4bd01aa5e2cb698f5e28f5b9bb638e242016c0bff85f4110027ad1d3022dcf018d2d2d586c651650a68709601d852ab17b00b
-27 1 20 \\xb3a95fc4b7678912c5c82b9975760ff014bf55573b2e9e3dba6437a49979b895ef72b3de59a9990b2ae8ea3749e2748ae6ff624b8543160ff21df0151acd6b08
-28 1 358 \\x78007eaa101bf164db2e9710644fc5de7938472a4a1993abfc024f779c9cbbc925ba851aa6e6feddec46bb001ee551288475214faf34e84ee828ace4a4e61e01
-29 1 22 \\xa1086ee861e329a96d932e921857b06fbf307f6383478b031604286d95ee31a10e1fc553a3ff282df10a9c53b1fe8e7734380d31d35de141744b055db633b20b
-30 1 207 \\x7bca098456b88dfa64bf9924b023f77f02150734d03bfda86de6e2ca7cf1b1b179bc5cb62e4e41540639e021f652ea085a4a159b936d95b6a1a518d1a2b48d00
-31 1 184 \\x14828242f3dbfcf48e8001d848233ad485d3dd7f814f4184bc4d1708129cc8f9ca86f0b1baa58bbe7ecc25b5cbe87c64b6fb06110ff17838de41edf047866107
-32 1 100 \\x409537254fd40a75d6edc5ecc5d1c215bdc26aac8e21f39897f9186d0e672aa4a06238a7638002bd966a5a6828a810bff6f9ccae8c85da19e4e5a192b0fa4607
-33 1 164 \\xec0ef3b7074c8a9e81b9404b0b89d5da931151dc189da556e5909671c52ea935c80eb21d1450bb664c5b6baf1c51079a09c2f93798b972afe98e7ae53e969a0a
-34 1 276 \\x2b63e017194e1e45ff8775a9432870772775f6f5d8785e2a1bac85511ac9c150db7a37557e8557b387c16d38b4b26bf61b85be636b1b44ee2d7be18fa1ea4b0a
-35 1 354 \\xc4649f87c3c3b7626b22b7a34f8302ab33de6cbb5cd3a84c74468b362108fc8ea5d32399119c07f14974b63705e7efac872d21269a458ebf1360d0d0b3de780f
-36 1 275 \\x0e033f9648e7e9d4c504700562f22be2f935404a0b67fcbaf8b26368db56a0dfd21f49710b29dc823f9fafc99a7f7b1b246aee82c8756de1aab448f97f09200b
-37 1 244 \\xdbc36806352a67be8fba48b29c030ac00b4cd132058fe382c79aa4ffcb1c3dc1c81cdcaea4ccb87b6764293c32f4e1d95f683942ac572d468c67a85fd3d27002
-38 1 407 \\x0711fd01af0e805fcd0a056b104ba123a146964c43add97fe19e957bfc816d82a834553520051794289f7a7cb9cf4f413fd4c755365f2f14d7b4cdb967eb7801
-39 1 222 \\x3e7d71cc70df93733d94a761dd517d3f208ff41c41294822c44be9a32dd3e19571b21afc5e3adccca7b037903d186b1113501904a519f0c00efb6e4179a4ba0f
-40 1 135 \\x3cab64bb04ee0ee399a269c7fcb41a26d5b6f6431a58bdb3f208ae8bf19fb6bd6e3f1dd1b16bfe8fbff883194e88b41718d51bb614ccbc32dcada8e2cdb52705
-41 1 131 \\xdbcc2671fe8a317e5a5a6550bafb20fedd89905ab6490f5a1bba9ffd214d23cf1665ea2df8f89062a26f63191e2c3d9bec3693fd2fe8bf71952ffcc2f8f2e20d
-42 1 66 \\x09a4f2b5ba715f34ec5d0f96c3d6070f572a134ad0b4a4044ab5a2cb428b71f075cbc10faafbe34c66d0d56d81f9ce402a81dc3f6ba50a6afb8deef271d1b10a
-43 1 293 \\x137ecfbb3e00c323331ac84051190f4579e58f893320f8828777e5c4a8308c57ea2ae72c27364a5e280af347b69c4d27aef5c9717fced7f0d82854c894e3cb08
-44 1 43 \\xf4f65a8342f4e70dac1241763b96b0d179f67e5c7fcf1bee7e1bba8b64003a5f858efde5f7df218785fb5443a510dd825b85af24d914236da33f53388f6c0c09
-45 1 299 \\x912413b2730bb5c01188504a4e099a0aa1c3a9d69977903ffbfdf365fa3b801aa6a87b021d0e062133811f4fc759b0f351f77c05fb2b15ee28e3d24c460ee60d
-46 1 138 \\x6a31e05f2bedf72a4559825926572af8c083ee68c966a4b30c5a676280876ba0d4864d44c4d2d0dff1723208f81ec3dbba8c53398237f32916bd258d43084500
-47 1 422 \\xbb11c24b5d67d26b569bdea7cb771d88ceaec174b0ea6860e6f566ce301c16af1f22aecf49467ec64a214a480b1a4706565d56533bcb253e4eb5bb885d00bd07
-48 1 235 \\x89c3898414eae1bc811de44bca8854ef86de76b6567c665867553c1657b9e75bb96126794082de9ec144e8dec5ac71768859b6bf87e59fc64e9cc157e3f02c0c
-49 1 418 \\xfec6039162180104f1760b62c6c5790500c7a7ced161845e65a47d19b17a5fbaab2204b7dcdd2c967b2a794164fec6f1cbd1c3a0746789fe748e1efc7853aa09
-50 1 234 \\x224f3fa2667f19143f3c25972a03bd092ab90796b9e6601e24bd1478f41fdd2ad3296d3b526ef1f16e8dbec40e63a713dc7398e00d35afcf282da1fb64a17e0a
-51 1 250 \\xe3cff870858e28b6ada565436de54049edcde29cc59123104c99da2620c38aae24ce4f6d5789fad9a153dd46884277550c3feac784c664fbbfc7fb8bebcb0207
-52 1 110 \\x50932b6ada5c4a3f46d9e3456abaeda08f5c519d85cba7a566c7c36d299001384b53e3d3d755c7e797398b5d5f35699661ec43c2e8205022d222149b90471306
-53 1 70 \\x3b4568d77bedc4083581596d1e12e2aa80c4c7807463372bb0abb5776ee52d99a11ae9db0f0672110ae03e944031e74c0d0e44297f8b2bc94a641f29ec7f8102
-54 1 159 \\x62f8e0c9c07a2b89d1b27e040e36c38e73f9ecb585b26d4ec421fb050eab51727b3c3a179e85f63c3a359b56b94cb538c4bd12b961b3fe8d6c4dcd6c9db51803
-55 1 7 \\xcd9e33bac91d40b7494a335088fa786d03f184832fd08b6c743a7816fcbe303db1ea7ee1945069329246034d2876c8a15ce9da1b4286421e8a8361688adebf04
-56 1 23 \\x7831be33ff270eb5651a033527a0af62f324e6341ba90d0ec2a7204c81b842724e454218d237d673e85103ce9100027860abdda657ed6d2663f8b803515f6606
-57 1 44 \\x450be824454fbade387aa5c81bc6a943ab34266dfc10b05c6ce22e890497112bd61c2d168ff0658ce16ce6cf619e16d5d26a58c0d563c3bb667616603c79b306
-58 1 340 \\x4d12a9146c9fea7796959d51fe34c021aec871310cfa052a06c491c78080e07e1aec868d6b053895869a2a88839d11cacc694b98911240c4cf6cc3f9b0dc2202
-59 1 88 \\xff4275072e4c565256ee8acdc04aaee4bd6cd27988d477ff120182e6151defd3f1396b20e833f800fc02d99e02682bb659abbe20f390d69f793d93bd183da30b
-60 1 69 \\x47b4b8410a9f849f4afe98461fecedea234fc09de7236c440880a70b22306b91195d02a18088c928c75eb679d0e080763234fda7a540771bf9566ec465773f0b
-61 1 247 \\xaefdb4c4d9f50f3d87f41e1a2880eb0a830bd77b6a70e95f673e1f52136db84e080f3d32d4062e7abcfe4d129d0d6127c457abeb9937c014ddeeb5e4427fdb03
-62 1 77 \\x11f59bec8cc389e3bf0645fc6a1c874fa96ddb851d8c1ce9337b0b531b2d4105b2281a3f0231a59cb96b89dc3098bc4ea13cc04eed3bfa393697e2b3e6dd2b0a
-63 1 49 \\x5a020208cf6082b3df2190ee44787369208db5d9841ed163de4ed55a3aa0903c795e8882d4c596a04465ca89668e148e8185ded9d375e12cc2e69c8de8f68a0a
-64 1 55 \\x6697643982a0fd39e6608b23f48ab14111d2bc3a9d07ff7c22c778d3068012d5bc71f50956c6875c70093d53d9427c5071c62c82ecce937ec05cfb98a7f46d05
-65 1 408 \\x0a9cdfe97346d35cf209cf423ddf3df6eed4482e806e59c2d8a738c93babe2c9c9420a3ee69ed53b4bbf1995388589bf3604a04e93aca244a7faea196bdeaf04
-66 1 170 \\xc770569c03e1b757305bc78d4b1403c467d833bd2d4711267ae78bb95626d6370fb1692868312157f89b1be4e391db8af558260ca8ac13916ba032c26fdb7e09
-67 1 424 \\xf03fbe51a4fe60c7d0c785af40dbb48360c12ec242864272fd532e960dfe7a63950c07f96aecd258a2c21fb9906f2252a4c5fe46dc7917f69e58b440b67c4c0e
-68 1 325 \\x852d04aaaced4e0de31c2b5eca3b52d022ca65a83ea52bcd69c7ce630f8db5e1339c17c1aa64e0b5373d784d920607ca2618f707fdda72a49a515f528b910d02
-69 1 174 \\xfb5c71ba90583742aa88141ab13cfbd22e79d7b6e4ff22fbfcef202a896cea8e06a9c007f45916a096b58ce9b282a7b970573e184b874192d5179ecdc325820d
-70 1 166 \\x10d7c106629bf0a8da213f1a82d125b67fe2fb2d756c4e7b7a239b7661841dd9fad64298da53d0ae3a18dbeb329dc0f0fab910a7631717ad30e79fdc7128c60e
-71 1 133 \\x8cef0a119ba393d7f3a94aeb8ec93f504d14a65434c64a102da9d1396621889a2dc9d321adddd6ee1c50c11a62e0adfb6adc2aed144c6d3f6aefc6bc8d449a09
-72 1 338 \\x79d312069ae475d90d0ae983e1f92d76a396e22b9d97b3d8c34b02fec192d479af1b03c3d715f792763ddc271aa44f36c0d7edd061579c683621171e01db080c
-73 1 85 \\x85addc0eac2b339c14e2ffda66d06ff8629813768015184eaeec5ac0f28517dce56b35a6d17694e268d616d181cbfcb0f3a8de06c1bab72a84a3246ebc030108
-74 1 248 \\x42a8d321e6e413b21fb324d7a26211abd9bc28c2bfda6ae3cf464d6fae5b883311de7948346f48f6133ef4dc6902c1ba90cbe06a5c5b920c769eb4343384d700
-75 1 314 \\x65fb7c5429d0db1a8116439c7cd28f0fde95b8ff9394b8943f796e25287acb1aa9bca0d74ed4b4eb9471ffdaa37fffa4c0171f0d82fabb3500cbc75ac9c11a05
-76 1 94 \\x8e283e3f672224218deab60800da9540b308e2a1c571fb281f2ec6ce121326e6404c3c333650e087e4a0f940b5c2793a0c073e1926bc77345ea5ba012d30cf02
-77 1 109 \\xfa87e468f2fc28f2934eeb8b27fea2679dc629cdd2f86fc3c86c7b6756818e4a3e9e1509add81ddfac79fdd4c50c53cbae310d4f2e16d1b44bb79c7d1de7380a
-78 1 266 \\xbaa1d34f44471ff2e892b57b3659309af26850aa7620a6b688eab3a3492b09abc53b11009dbd9dc138a52406fdd11676526494f53dc86c5028a6c4a62b95de06
-79 1 363 \\xbb82bba281f487c1a3ff44154b5f3c0c05e845ba957216b228515cbeee4ae4da9348ab3d41f7d9c31fc41abf0dc5101954ee1e595632563d2bf17074e6334f01
-80 1 281 \\x08e76c3fad8dc312d27a31c45cf39bf409545fcc92216f8d46b8b94eca36081ba6daabd379bd34dcbb285e5cf61beb57137a591abf2b97973d626618bc016b08
-81 1 258 \\x1bb4b4cb2b1e1ae5f040b20bf6a4abe8aa393b8462d80acde244aa181c1998262c3a89e6af00180b972cb056c6a7e21562b98e503f67e33afda1c3a1c230f705
-82 1 142 \\xc8290db4e253786144ff690d92a02888e95cc8d8f7f2a4e0a382d558b0647d823b4119e356f677ceaad8a3022a88b137fed35a35f04d19c8ed7f6ef578cb4e0c
-83 1 208 \\x0cd9cc4130de6dbf44d85c6daeb363144daffd9afcab863d15a017c618ea382bd4533f50cce2df29ff7ec51fd32ffa6933ecaf5ed83ba29e8cd3726bb26c8303
-84 1 60 \\xde386e9aaa5d786f01a72f640ec8ab415f35693807b86210a8f4e1f9deeb88dad4bf174613ffb758a0da6460e11aa60c464d272adbb001c4850998e835e2fd00
-85 1 126 \\xeb293e42a8781cd5ee0ab59ec352f7333d5819824da56a3e18f55d76e989d5db155e44940f0e69e9a3ad89b39fbd1331a8a24af955ce6dfb686d26c1422dae03
-86 1 297 \\xe7a8220f27ccb32003cb8f1e571872094f768d96223fc8f9782dbb18934586be17e6961af6469aaf27e63609ed00319c7e3d9f0176562bfd06ea07f881d89507
-87 1 127 \\x5d13d200b6b7b970fa7b89a607f6118b1a1b87f80f48469c9c0378a35c160e35d75d4d48f0459c8b2bf167d513a7746af5aafc86b4fee94492e460cc13050304
-88 1 241 \\x3b61fdb9952496911f4b4c108d8c0377783b28c589247b76ffa3d5f9ad3ce6d9f99abd593389a2fc93f7c1c94859c87063a80ca12f5b98c2daaefd989637840c
-89 1 390 \\x5baf9104b46daeee303b5ae7d28dabcef60873675482c7d7d41b006b59aab0cbd46abb69bf2714c3b3660adc52f665c42bccb16e458f752e45eb26bb6f90f208
-90 1 130 \\x556570857287c29ceb0d7b141b51b47c512d69728a11cea0330119f9a9a68d03f7372cbac1e4ac11d72dd2a52c9f7cbbf38e80e29b54a538b96ab92452951101
-91 1 284 \\x3a8658e15ba52967e946d97109961903a8ecb5f509fc7ac22eeafa5a9e1f1e8c251fb8d0cb8835a74fb3b93f958ad9394a9cdc62c4b379f3f4711ac51cc01c06
-92 1 178 \\x595d48a50e87965314e13328f4a72e47e931c88239f20394bf6b1df5f1a7236adc8a994ddb88fcdf694c3b2601025df8ea77180cec70c3fd56f0426a3d7c5207
-93 1 111 \\x3b7e5b82ebac0400792b0b76e8858cdb44b09ca24141b527e6b47e445f5c03dbd54d1e2d4627a3cbe1c9f063e41f5978656cb104f310b6da9250eefae5fe6103
-94 1 185 \\xc2f60e39389a152566da4267ae4294d907b0c4607c8787b2ca42055c73c59a0ddbb6110018fc76c821bbd452d1583acc6a79dcaa8950c5d2f55365b70053da03
-95 1 119 \\x7a38630bac15ed9408a6aefd2c5691c2b0d23b4a904bb52e399f7faf91a7155b79d2ba82de907d0e76721644f1c7c2c30d392019f3639d4b5dd95feca5b48a04
-96 1 307 \\xd07cc4c57f90253c13b875d3235cc93a9033e2a094785bc3fc40c057b6c99ea57d2b86531a5d3e0147b3e3e23d457fd1cdb932f68c10b620a1ba8b24e246d602
-97 1 345 \\x8582aa6726de25dba631c5a57f46e56a99bd0b3bcda7e7872374f09f6657d7c8abb1107fa3afedfdede5de35e63acf656d0dbab13189ea8342fc00506d37fa0f
-98 1 342 \\x8a5305a6778c386d376bfaacef0d8c2c7fec135e53a6232e1e32f319aa9404f81d45682467f69b02a5beb73ffeb7ce5f59ea10f1f20aff23b0a9ebe8d92b2809
-99 1 226 \\x383eb2ac2fc6ebb44e6d74da119f28024cce22abe5278fe6e14867d4661c80b18e0e6dd5b66f1c592ceaeaee6aec60dbcab42eae2e2e9a2ebdacfa6d9d1ca402
-100 1 403 \\xb81cf6b79b628a2589c93f2a20c3ca7a56af058ae9e78fee851a10b2c40c2c6dc4a81611e92ec857d7d394dde784b21080165bc80ec4a72540ff1b1fd9751207
-101 1 417 \\x8c33e52ddbe9f6005736a106aec46b3ba081c59a01ef90c7ba4a728d4d3d311f001f81be992eb2be48259ff83189b2a52064d33119b291626399142e0614ee03
-102 1 154 \\xf02f8121af48e2cf2978596ac13626ec6a3c7b4489d45362b499dc03ae189eda9ff3ee5b79922b6e99210c5e3f6d83e202bd66480bfb9d7cf22796a84dec670b
-103 1 58 \\xffda8423da3f20164be52f6a8b607c4768702c0ca37978da64c412711571057dbfeabce2a2b221b24bccd29d77e184d193541e91486a15e3c92c7a7c606ffb00
-104 1 188 \\xf954b4851c17a6180502a895e0fbf1856aa7d036c4b8c1b9bea7ede54e5514a6f8c4d0faa7783f2373491e811f64c8020ae2788634482dbd96c76f16f8044c0d
-105 1 399 \\x8ec72b45a4981ce79c999f975fb7d45f858b1b455bc09563ec3b6d68f21bb6c58b004c6b63ef4a3daf52221bdd25ac3dea7c3acfa9c0f2c0aaccd5da4a6a3e07
-106 1 183 \\x62691b6ad2b306b6a4a76d692436f960dae16b3eaa081eeebb5e4a85fb5f5769f416572489fedd05e14ddbaad5ebbdd1eeb63ca7ce558292501d8a4eb1360a0b
-107 1 216 \\xff5e24f460339eb6f9c36d505acb79b78a2dc38523f87030e28409e9588745c47461c290889ec41c277bfae1743bd0c10ac9487663bb52c1c73492f78eba4000
-108 1 406 \\xf40f4d0dced1931805ed39a948b5f1b30f2828df034b846981bdf4e0787b00855b889c2140c61bf7ee275fc1b1c7c63a7941695a149f85b5f7aa08a753f23508
-109 1 199 \\xb2013eda749021420c600886306f3e4850989599cedde2f5a5d23f2a8ade3f580186d02111d98c51528e8fb5e15282ec41788ff66ad68b83e81eff03fd97ac05
-110 1 52 \\x01320a094d4d6bde8d7be813a2ac14d1f414802e8bb8b9145bf5abde24682b58f49b79018e0183f8573777c6417acfb48c79fece495840726816260fd27bea0a
-111 1 349 \\x3ea29677be4387ca4829b74cc8a996333b0f106dcdf5ef04a83737e8765c8d1dcf6b65d85ca88260493ca51c989ff7eb77d17ced9a9f5455ab28890aa4e46e0a
-112 1 272 \\xccdc8fc65cb5aed9776720425340649dd0b33283505d28f7ca17346f4a8691a38f272ff34940c6c4c96ebe5c41ae54d8eac382beb5153b085983895c9ea6160e
-113 1 278 \\xb736d3d60e84317a62c58400795594ef7aa36ad6724cf3613ee7870c4bf760cb66e60e0efa8cd0297809d97a156f57060d6336af9643cf2f5e331d818e75b504
-114 1 356 \\x39b226b626c42dab0b70ccc31e2be3ce9377a06c10c8860799b295d8f6e99e1abf3932dce147a0d49a0cbbc7f1de54c3a406fc7c68dfa3c90217b6c45433d303
-115 1 310 \\x3b7eb8041746f9c715a3a9c3669ee4e48561cd52865da33a316da6533c0cdc304553fd2f9012c6e72c45d8144230658d17336e7148195ce258d9ec342b8cc605
-116 1 140 \\x17133cf226b5fb6686b12b17453211fe8b15801f7f529ba4bd292a2ca7ed334296874764231d6df66a7d088d0ec6fdb93ff78b0c573b2b3277797ae073dfbd00
-117 1 182 \\xaaebd22ef74047355203192b757e4d9ba164d3d878b0e046e259bbf2af32b176cacd30cbf2c4e718968f193cd2e5820c3b8d6bc375524aec8661b9d0ac41fc00
-118 1 186 \\x6510ba3fc965f1bff228f6b8002370f37dd184fe5798895951cac210a760aac11fdaa824163ed17c41e401613f5b73d4b52cc81d6a6c6858a76dbf772cfedc03
-119 1 14 \\x218e5c4f7f4f5ab6d7d017c2d2648e735de85ac7690ada5dbcd37dac6baa84193f850bf9a660c67c59929047a2a835e593f7838e1df6a1c3499d7c4dc8a76b01
-120 1 209 \\x7934862c301537a35b3caad6e88a41706964db6293e384002790ffd249d1142223bccd50f77999247aa75546cab6d45dd9c896a8761d3705f33660f26b5aa605
-121 1 329 \\x7037064360551c6ef88eacb0c324ce456abd4cbbb90959af5bf45458f7a626f94d1aa396fb191b1cf914beef577ebb488e9e407479ae5c59ff3714445b72bf00
-122 1 229 \\xb8392a4feba7c07ae81f0d8c5df8fd55452aeda51fb706c94ab86ed0830a876f64f4a72401a6972160da14cae0d608065d48382ca6ac156d20f049d2138ea407
-123 1 81 \\xb138c7c6f2a3bc1e152d974f9555d73e43e1ba43d8e8add800266bd10a1072a48c20c86652d56c2eef772ea1799213b33af376e4040d2cee21283dd3de27e00a
-124 1 384 \\x15275ea74605a60624d53f5b5c2a399f4275d9c198ca8250591b40de568c14de1afdf08f9d1afa9ea77f26d5b0f60013327ffaa33f2e96432625250a2439120e
-125 1 92 \\x50d08c47ef4cd25220bb9cd6277643766bec72a539168a3a478ed0f9e54f5db0d42af7e2748e3bd4110841c37cb7a381d429cfea050a8fcf319a22f84185fa0b
-126 1 176 \\x77a9fdf79472d75dc7cbf55716879d91bb1bfaa24f2261b218abe15cdc087fef5c378ce5cbf8f81fd46d30ebc85bdd73e061171f45f0bca1058d6d766bdc1a02
-127 1 343 \\x86493a76ecfd7caa62aadd58761d32170e03b9ad8090331f812d0e33f86eef29ec4f7df78b2c5ea7350a610ba330c7723ebbdb6f55fbbde8cd0eab382dd7ac03
-128 1 401 \\x7fb41ed603c731264fc7b2a85f17bace62b5186bf59221ca159a9e36c816ddce5669c012b06cd6eb717d12478cf567f7786b938206221b460f0c1f97d77de60f
-129 1 254 \\x4fe58470a96ca1e58a40eb935585b203d847e0d76346dbb1bd74ed319b40a357144b65c7a43947afc3b7c7c8450c45cfb7bc304b3cf85cc3e173f52a69a28300
-130 1 187 \\x2b0f38dfad897fa2df7cf8dca9f27eae6d3e2fa3140ebf58eddd44dae4a8dd6f0bb5435aa4efe6b07b50ae2533459e852d351b6845e06a0d0d5f46f776155d0d
-131 1 288 \\x27eb997648fe0ddca8547e22a2d96fec04088cecade58312d2b1dbd54a5fef52ddc62b614a82769613e216cb1ee7e8366dd4fa377ad29b793687cdc33cef8107
-132 1 333 \\xbe0b24124bc4dab023562816dffd002ce42d0db8d573ec12f30ed446f1ecf080ddd4c1ba76ae7760a081584b8a9e1d75820d3f05afb0493a11cada67a7e8a307
-133 1 367 \\xd752c8e68bc01fc1e960a0a4f262729cee427ee36b581deaf20cb4eceefcf896f7a1e211369f07c4e6bd9499669ef1c158492734161b52fd870083a60ec52a09
-134 1 370 \\x14a81688ac8710aa49187dfe334893b4fbafb1932220b07ab94606de47b415cfb2a7ed4f3a380eed31ce904eac42a37bc12d86b3abe5b88475a90ba54a304d0a
-135 1 217 \\xd5880bd0a916f21b4302455b3daae05ce8e987411def6c46fd13afeb3aa5b8ca7e0d63c3939d639d474813cd3ea927cb6b866c37a36476efbb2ed865ed29c209
-136 1 121 \\x6baeb0eb2140b7651d3087b34f218597609d48fc8c36ea0c77f3ae4b46cb4871990edfe8ab71a8c5615ce9d65f0f58b3ebb238f04d4c781c35344932603f4809
-137 1 347 \\x5544c7da14efe11b7f2ba2fd81d1fb7b9b612a25deef396a724262587c1b6ffee6b98b5cdd54b78c9661e714e567f5852832928a427ae71f580af004a2112505
-138 1 129 \\xaba065f2cf19b7d9da79ada2083c722b59bb9827214cb0d65ac4da0a6441ee037c8afb2e3aa8c8e466fcf81cd7d21a2de77b8ec8d4480c3b128d589d4c21920c
-139 1 283 \\xdb05e88cbcd9cf845d24a07399df560a3794c2a670dc474adbd34e4af2573afff5a8bfae6149967deb25fee6af8cb5be7dfe263b719218784fcf57f969601a09
-140 1 339 \\x53b4f5e274f8ca46ee5020328dda5fbf33e511b422a1d3e727ac0f60e28c51b296a2991e6cc99ff7be262fcb69d6ce20148dd7ad1fc9450dcd62b4cc8f8bc70a
-141 1 201 \\x9a6a5dc41c59528f3121152be6c7afab324a6ca154389c033cbaad87d8ac92907f058d112854245a0302eff4c9e90036992c01fab2a6d9b95234e0f749d51204
-142 1 265 \\x96d9b845bc74c20dcfb2f3a73a5fd039246696dceaf579322923b9ee4ff92cdc15ffd00946061b180bbb08a53d076e8bffcc2f568da248f5c9dd659a8d7b8b0f
-143 1 271 \\x2236462f3af0a8452e8634b1a9aed7a56c023cb5487f40e7d040b8dd921fb44266c422f783052e86a096646125bbc6e007844e4aec5538afcf5eb1bfe6d06f0e
-144 1 141 \\x8d3392e887f3b53f2db9f6b38849fc57cf0574fab7a1e652f55b824a907977cbbf23038eb421471778b923b3977b16227c7c891eafa454ec47347e858e914d03
-145 1 124 \\x31b20b02f0527b1460555a638911a23ef1bc11cb38e14aeb3a963bf845f8dc2c80ca7ec82a134ebebef9290b880e5a01868429420e4d02c934187e38a630590b
-146 1 190 \\xad2ce7fa514121469fa3ba26f34bf5e3e89f49c4f2af3b0a85ccdf571a0dd4c5a73e8af90a2a3916ee064105b0a527da374bcb9d287161cc9085919cb6466b06
-147 1 76 \\x14714b71734f8cf6bde7c9a069b92ad692bd73364d82ea2a159d833c834dbdedaa192eaf57a62185c207afa6a4eca85e1f49b6cb345148517ecd011d1891ea06
-148 1 1 \\x9cfffe417740092fa8145a63f64307ef7acc8a2b32630af2ba2820e9ac13b60c7c5fd96e71ccbf9ee393398f296f5ec6abd732a1b21a1614cbd4610b06784808
-149 1 232 \\xbd49f54c2027357bb72a1a13da39ee9052190a51fa4da4ac0909aee453a7427b8722b2fd90cdc59b0cd2020660079609d9204d031f87e4a99911ef12d0e2800a
-150 1 305 \\xcaec985bff0b48663782a30da1c7d71dcf975d6d74d9cb5df3a840c05e4361fb4c5a9a320d8eb6284e09e87ff1b9ae8f641bcbd744d0ffdb7bfc5c59b3e1ec03
-151 1 378 \\xc92879607a7b8d053ba29eb36b75671388af378731e969b53e6bb3c8d2ff1edadcc91bddb1b005e19ea3a7a3e54f8a40862a888942aaa1ad15572ae16518f70b
-152 1 50 \\xf689f474fa0fdf493cb00ce3e977541d97e4766669344d9bebcb6380b838330679476d1242a1f020f536a485e59c86b0edecef6360fc888748562796dcea0108
-153 1 365 \\x8cfc0ea7c8a76f05e51e824bf38f1a857719a2d141f3783703937153ba4b745513c49a59c2705a05275bf1f2b4d4d282a938833bb1db57dd5a579266359f8e06
-154 1 360 \\x143b2a89b52f4b8f77ba7b76ff7f9a759b702cca9fd8691d80f1be73cf3377e902f36acc6988a039a8d9fa738b5a847e306116aeb9e7b932fddf6e7b2ff3f108
-155 1 120 \\xc0061c6312560b766e73bf78c0b32b232cf0924ad335ede0539853521d751e0e97328ce61578401412f614aee8df26e6ca6ce81f4426d01254876d9d7f22c004
-156 1 273 \\xbde43cc3a3b5b18e89d704cdd477f2daf03cf79c7d0e41300466e8b45ab915ed0636f3ff86e23607aa3d09e7eb1f2588041ea964017dbad7c186281cb9eea904
-157 1 328 \\x00415a426cad2f007092c035fc53ae548a1103f31e72566cc82a358c448c55ab233fb9e72e49736e735d8cb8f23ff7bed73d3dd0da83d5f91f9c8c4d4acba508
-158 1 372 \\xc4448f841a59cc12d502bc056f71ef1985ef352d9f725ba321960f88b0352405acd4adbf56403ade769a175f4d1b058a88eebd6ee223b56d42b500e4f29d8707
-159 1 315 \\xc109dae837c5b05c3feb28a6eddb6c598b4cd7bca1450d7990a5eaeb86f717ff20da51f2da834386d827c6a9c1c090e3777ab494e8b5bbbe0b4d43b57946cc00
-160 1 93 \\x07650bb4ebb682b3365f2692ba808469e6782cb898533bf1b014ef398efecae800b654639c728332b7c5f186f27ab49448721ecdeca5228588e08143d051dd0d
-161 1 313 \\xea890bd690316cb330baa628d8d81bde445fb729af3bedac9321a7d84af9220c0835933a446fa56f4741e3b2f585ae508e8a5eef8aee1dd3097dfbe6fea4aa07
-162 1 78 \\x504f783c00958491e4eabc782b86e3dad315bdfa9a83dee6f018d4e459b3b082466eb5e0b0a26ab432d6c9041af7439363a0ce21eb5620eee07853521d21a202
-163 1 113 \\x65934bfac324db912a418555cb79746f9c696d241e1bf68622cca4a54ccaeb0483fce1d912c28242831547e841369fae276a2ca19ba5e1f2b8c151873143cc0a
-164 1 385 \\xa31ea49e85c73f067fff6f24fca2021fbe66ea4bbc2d9e7bd0ea18a28118b38be902c0209038b74ecae6f1d3161760359761d1d01ddcd79ab30033a7aa278404
-165 1 151 \\xef69e8935fa05ea07a3f0cf669f4e01fc2dd18c24816a77ceb38278af26c781af0cadfa7b124f3cd2b9aa4d77c790d9ceb03acbb3c5979f6872ed60c7889a200
-166 1 204 \\xeff5949d513ee9768948bc08d48a40e4ede1902dca59d9c1ab5a4934cffbeb535776d87b3d5074475bf5a9d2cdf828e52efab3e9c02cf320383e2705e57e7b0d
-167 1 353 \\x74094b85333836b05976403e5de8270b48de484fe65bc4ce6a3d38e98b56e1fd957f267032ffbd5eb197cab48a14099241292f741d1353531e1634bf2731ff01
-168 1 61 \\xcf4f5244c0773b4a278e68a605cfcffca3c65d6c85bd684609a1a65567cea1aacbab433435b509d99375485aa3a4e9c204c6ca1a4bea86c73b88895043e05b03
-169 1 3 \\xd6b6b18feb16c766ea4ea3b6cf9e88ee91a15cba530e7c0eef0f512116345cf07aed84c7a7e247e34111868950e4252f895187b5e8f9c96706fb6b625d7b1705
-170 1 291 \\x7eaf5d0a72bd48942a8a0386728ba1c1b68cebcec3fa6ac74ab28741dc3b1ec69fbf510fa0cfa08fd557ddcbfda96b357e3ea0560520c9fdf42e33b1267db504
-171 1 63 \\x5302913696991128e3c406729150e0aec00f4a5194d142b12be07a3086f6cae19a3f55d9c7766dcb7455042f822d39227a7a9fcb27a8caaa33f079bbd818b003
-172 1 270 \\x2ffb73dfede01d9dcad5fa92950ec121a126b3bc9c230f16044b1e40c4d79a86d497e6fa0bae9d8b0c151b064525f9c4417b9a8fd9927fd9ef80d822e4e35f05
-173 1 412 \\xb9f22f5d9eaf6998619825ff1cf55395c10bf41775eff0b4fa15fcd9867c0c1482928f24abc1d993e306118476fb99c0100ff0cd9ea77a9eb07fe6d2d3012f04
-174 1 324 \\x7346752d2f150e326c379a23e189beaf3b6182f6b089e805c0ab3e42c97f789885872cf280f762ba945548cbe07f8edb5d4272869dfddf58f8d7269766243b0c
-175 1 369 \\x9d8b3052e57c2973c6eb0b305d17220b19d2acd0a2096f2aafd74efc62fc27c0cbd280fa27e867fb016c985259c283b973b3de8bd51b85a09115d3ea22237a04
-176 1 260 \\xeea5bc92874a056768a872791acdeea8885bd30158670eaa6640bb453e4ecdebf9ba57c0e22e8d12a005ff4d21a8df2498b49fdf0e3c5ab31867631e7e168d0d
-177 1 377 \\x1de8786ad16c4fc7713fc5196a684fc253f25711933e1529baa5f367c30deeafb4b64df4d319856f89f5c9073e762862fb75580d34e84f23b9ce6124a41c7f07
-178 1 311 \\x354ba1c0dcaa237bf250170fcd986b9aa22f8c5ac9fff6d6db3a03972fa389f359242af81eb25d571cd21a3cd282cb7854e14bfe3706c68b99de9107a8e7330d
-179 1 306 \\x08bd7dbd019c1d78441707022a3a43b0fd4e480df06660b80d16f5ce8a2af4b7ddb3488dfe0b6eb601b4d2ae848123d524a265a27971d0e382a62adb1b817902
-180 1 396 \\x47f046fb0bd748c54d9d5dd39175c7d43e3af06ef8f7033db29a261630620e28f8da3094c3062a62f795d4b70219e7a5b2780573db33938d9188a052d2642c0a
-181 1 279 \\x8e8a1ee1484a0b9f44ae40c6024c8bf8b5b50579fbe21f90ed4d4bd5929b95dd1c3527f468da24f328d23f45506340b98b8fb35a22356dc1de9d25d6f3c4ab05
-182 1 41 \\xc65a9c738e407780496f99bf5952fad6df266dd0940769ac2280094158872b716d9a452b6b13003c0117888b6b64cb1f49a55308f98c70f78de0252b2567010d
-183 1 255 \\x6e16124b028b5014816c1cc939543e212f09065741f36c5b83b362df265442ebfea1358ecddfe686db6c145ad928ed92e4756a2cd1ab3b5776e9a98e954e730f
-184 1 86 \\x23a2bbf34cd508d442c78aec116d93d101efa6dcaa7e1fb1129122ccd59853757d1bb9139c862982af67dd8427e44d94ef97b0f04f89382a2777bfc32efb6a0d
-185 1 400 \\xfbe415a6ff34b4012a802e38276a68c8fe158755c3f4175692174e3f0efa88938817801ee0f274f0d0d2368fe808336670571bec91d11d79bcfdf4f603317205
-186 1 214 \\x8ca66caa1c556fcf6ff2d5641d679bf375723faffa87555bca333615efd5564ce1376394a6679b43ea335151ce540e7605e8260cfbff00386fc93226b32c6a0a
-187 1 375 \\x2b007c4b776d950303ed5cb439e2d29efd20ab911492ed9660a4d8d4fd873a4035a09368af86834c863fa8d62529993ccf920bd686c6bed0eedf5251dad1170d
-188 1 26 \\x1192d045a74bfc63c769c39542720e6656445a57143b36bd7f57c2912fd86e89719bf73f8fe3f2b56f2f02f46831bf3484707729f7c9c9c261ce869a49432e04
-189 1 318 \\xd497c2b9c2876ef3a91338a7b050ead167be21adab4c0636e465cdc63ddb9b1110b365365d7e2de99ddfab56d4f339902db6c8d1bb70b908b0abed0f58f73009
-190 1 35 \\x10022807b6f1b511fd76083031b696e09912766e6b386cf329e5dcbfba9698893ac5f60f83484e7c8dccd334f0df56c83798671a497bb2ef5a5428dd96e5f605
-191 1 12 \\x443228d4a1c14c9941df9c359343130d2460295130fe2ca84c23be34253f8180ca54384ef697ad47eaba71ee97a3791e4aeed31eb418f5df920a54d96cf4e40f
-192 1 327 \\x3ce62939da6288b1311122ca2f989e41a29523df46e680a1dfa49e413bbc8ae39a836a595ff79425db02bea0c23abfdc9ee7a399e58d0f8989f93866c3d3e402
-193 1 206 \\x01cb173564e9460630cad4204a7649dad40193d98d83aa5db32f000db3009a32f77f32911771ec0a7b624b9039ac166db1a87c56c980c0aa184fa933fc003f0f
-194 1 136 \\x86366958bd10b2841ee24ed10df4a3447510c21c7fe4ae51a517558825d75f7ea4f85d7684f06017749ff08f7711d583972285644075fc31aa676d772d38f603
-195 1 48 \\x36e69e3d48589e205752049122c2870d70007a7ead6fff607696d7b21f7aee1385124a8b502a2c70b3073ae123a2f5e4f51dbacd781989c73c87ddb94750d107
-196 1 286 \\xd5749a3c5b3cb2b9b9a5cb0eb0e94015c67f45fdd52691c40e2a7266bec9ecb8aabb4c5bac895e21f286590711e87fc183e935489a77b8e9bdc9976224d4c00b
-197 1 37 \\x0ff863f2a70cec80e6569b73084a97b34508cc25afe60a264b176c4317c8396b8313909b085db03b565a1551f54f1071e5389cd39aaa8a1c8936958cea65a307
-198 1 350 \\x0f87f05ecb8ecd5e34464d0711acf23004d7200598c8ddb316c796d939b8ea0f3621bd8df67a31a015b5fc5aa5ff9eb9de9c877cfc6235118b1ee366082ddd0c
-199 1 90 \\x5aa3fb981cc0477bbf93afa7e23854a92fb4402ccde5cc041cb22754cef818b1bc903b5bfef4d98bc0c8718514f5c652917124348b739573510151053416e501
-200 1 103 \\xa24f65b5336fe977bc3c1e9baa8247ce63e89e2a798b6a1a7c0b0dafed3a4d4ebe82a50f914b563a4ce76d9c7139a4a3a34266a8ff511778e49607632d1eb008
-201 1 152 \\xa869844f218d7e4dc027c05deb071db5aa16462cf9ece7c9a4a9bcf7d32b30b4dcff2a64142cec6460961fe862876ef263e7a2ad59d8d45da97db64d8efb1c01
-202 1 95 \\x0a960d1244a5b8fb6e7db08d0a34d7a19cfbf2b6b135ac6262378e33206e802dd4cf3e37ddd6cc31d1b16ff51d5edc0b09a76f18d9393e15b64c4773f0afc50c
-203 1 282 \\x8ae867d302aec28c21411b818c57074b40cdfedb8a6556dffc20859298b811156dffdf03802190d287c82b0f943552446cc2981dfb9ea3b04e7f692243ee9105
-204 1 249 \\x20fa2c32f98e7e92107bc85cc0698d68edc4ffcc6670b9d51929d7cef8a55591b94b00379d7a486c2912399bd44a25e35b55d5acddabd91312c28f73a01f5b08
-205 1 319 \\x6b30e5adfc83fc65d4b988c1b5bafac98a78cdf8731c864920b8dff2d9bbccf670b1ef3df1fefa3be9a22ab5c058207ea27657568c3874cdcbb208d470c0de00
-206 1 398 \\xbcbb8337b930587efe2a24db1858ecf00edba5dd89aa7bc75cc23b5fc717b0680b2781c684128cfff619be7b026397c0b30db87333fa021003f9ff162fe6ba00
-207 1 98 \\x8cd8908a624e554dc42ea5f0ce499d10af641b83f1e6b00dc6762ffc1d39d967ee906a9b060333d46e6f0a1e49fc01077d81eff16a85a827d7f213d6a372c40a
-208 1 280 \\x66f19f06d47a3f4a52a16432fb9a1b7ebaed5d8ec59f8dff123447b9518bf4c010e4977e0bdea26225a69de8ec1100924bb2bf7e9fec708c18f21804f59d3204
-209 1 71 \\x77723552669cef8df4085da0922f2ce2d9748d915929907b3db09f88c6263658eddaa6a8744afdfa54d91d231f8afb6134becfd8fd9976832c1792a48859e30d
-210 1 56 \\xffa369594479078bd93292e8f5e2e6af968c7f96410f61391f7de0aa9a66e7992720dbf3ae0bce7586fadb80536abced1f5957ea63c0d61a13a37660ae8a8103
-211 1 173 \\x8a8c2dc13f8c680f30ce2d2e4de4600aef1ff015be36b823bc7c6e6c4af7a9da22b5ce02aa5aebee17622c9bf806847b247ccdadda6f0c9429a87c05ea008f02
-212 1 290 \\xc4fd12f912940b4a86d304edb962e5a974ca0293a4e6f52da9039edd867a7c0863857136b5f89c48c38f08da290d0943b15212949776a5cc18c754a182d00a09
-213 1 15 \\x96b1cc421f973edb79fce0337151c0e95ecf04ec47351a72f3553167de845491629a1f8f92a01f8e34dc8903796b88d1482057d4e6f1f4879120ac84658c950c
-214 1 386 \\x27710a4c92d4665e8506606c622b3ae90232261eede5ce927d4f75724867326ec93be6b03040a664837910919feb7cefc5eaaa66e51380b7c223da17c9a2ac00
-215 1 259 \\xe41578f333b2a58c305198221ad0782777b9521076e1dc00f7fafe71a5cd738c3553e2bbd1b6457884aeba543ec0f471e832c675fa758195cfc6bde35d37950f
-216 1 163 \\xc6dd73c32a70d232fa61f6cd6b13d08b5cf5211fd3a1308fe5ca111ce843da9b803f89454adcdbc0b82e948659540b60791f2b7cb8bdd0e434c4e19413b23c0b
-217 1 409 \\x4f59e87406a5e86d4a8598adb7023def0418f4773f14634fca09e4c8f837bbd2271e94e14fdc92adfdbdb34f334db4d2951618d60cfc250ae55e633b53ae5903
-218 1 114 \\x607d39db12b28d54606bd792992cdff5e1f3a75192a29145865542921bbba5f156d35d402dbdb3debe716d8280c10e6d548041441036658405a91fbb600fe305
-219 1 219 \\x1c4af85f13e0b4e705a1ead3530b4ceb8515c9b39df17e15c87fb99a289faa9a5e7a980e92480c2669b93ac660881c2fb956ca613d6871d6234491096a6e8501
-220 1 267 \\xb0acf534651199bff4393942480ff8b2acba4637a2da876be87e9d025b20b02948dc123701f453974db160454dc1c2f31895bb0779cb92b0d5d1e59556517108
-221 1 246 \\xfe36c536e00325358e310e5c55e680fcab8d818c428ff4831e24507b03a747fe9e4c6b167c437bf61a577d5479b395c6b03457829a2af07f908d0900dfa7f90d
-222 1 218 \\x191cde049e1c1e08b2c29ceef1638d4823341e63afcf8b98be5e9746b6b9411bc87e15f3a3d3576fa0f9fc3d475d19ec34e007867f861a8815ce712398c23a01
-223 1 31 \\x0684897238298dd0efe1754ff6281716fd073690310d900887c2b9668ba2db3e7635dd46db802d514aa27717bb877b811cdd66a66049401b2cc4e80bfb698b0e
-224 1 75 \\x83851cdbaec68b71f8ef848655ae3d41fd8a66e6ca41add6fc71b99788df393191e1116ac0338d783a981978527d095620a21ae12e2e8b9ae80ba6560f6c8b0d
-225 1 359 \\x97225e40474b73a616813fc3a14c2fef198ba3f84fd908f0df80722572814af1241f4be5cb72a730d4eba42a30824c8447547bbf4b06a92f0ae27321bbb3a30c
-226 1 421 \\x6ec1038610c149455d67b08cc4f462db0afc0648c30d50d8272e668372bfca08e58a9b2a9bfee939ee1fa9cbf62232352991ef0fb8b0eac8b4b1e57118ce6802
-227 1 59 \\xcf902136780354a56cc006879135948331e33a18926f6aaf4e319652b3791a6140491cb4c5af1c493e343e4f046d3da9fe257c55ba063b76b4ed9d3159f2c709
-228 1 149 \\x8beaffedada7e45847ec13732f0947ed39c305b1e9f06437d5e41e9e111d5c66cc7790fbf920f2d38fabcafe60cff10b9504d104ec51faa9c282e1bb230d170d
-229 1 28 \\xe19525a95be0b311f2d4d3f55eb2447a9792e1848d1b774b7deb61b2df49642523248d215d10c0ca7e7c3a751f440139d4191b1f92c4147ed8b1e015d7179100
-230 1 202 \\x8eedee617cb62e601a958918375e36ac98d76f19a0b3369512964f520695bc9a27d2189a54751cd2094c18cee064bd7ee4ed168bc54b0e4b3f99371712d37c0e
-231 1 383 \\x615ddb8b49508de43b42194516dfd6028c799d33b6904e16c8356811a906d4e98aca150822f9ddce8b7c2c01135d70e8fea6729c6c9bbf8e732f9c62a9ff0105
-232 1 32 \\x6c73e9688248ecda3a6bc5863389be689339e65df52d80f359a8b726e689288f75bc1b871acbd8235daffe93558e3398f90c883250a773396a61097d2ef73e05
-233 1 330 \\x2549258093dac74d6c29ee3ed9868a50022469566963bc9ef7b17db8036fc77c07ca675bba42bc7839a211f5571e878c9858b2bfc3db19e8e6069802c6524c0f
-234 1 79 \\x1ae51f484f9ee0346799b5be6385bc6ae765cb6df534ca4e0df581ff55e561e8757c0e6265f9664a6c99bb8629acd751d1a6bea9260c4c6b202898c9a1365a08
-235 1 205 \\xdd5471665cb123d253512e233ec0285df6d8d054245db2262256833343088b940c278d59086f4ecca35c11cf21d3cbea0492c8fd5c7a74be7eff962c0b17100d
-236 1 341 \\x621a5de545efc51905d25aa9653ff0643c759924f6dd572b7ca6eb4f0b6c7747eed0445dd34e4ed884dbfc809bdabb6ff35706c224b538e5cb31ace7c4ea5b04
-237 1 320 \\x86ddff69562ced3bbc0c4c01a8a26ec6361662d1fcba4b05b6e750b3a3276b4d88e632241d30e6dc115969723e06671086ac0cff9673757e21b198b425b2630c
-238 1 237 \\xc53843b9dcb4a52bdcff456f79ae086cb5d0c8e252a8a82cd7db980a51af9116c71078f76d5a8386c6129e0010660a0c9da42e79cee576050e45f0db24bead06
-239 1 99 \\x1a86417b373f38a4772403e53338a064c527aa2494dbde84ce58cfcd3768970d2d115c8d397f39d89cda6b75bab1f54dda221158c544629558b5e18ed04f1f0b
-240 1 357 \\x060975aa054956fffdbee8857365bef37027c3f31383c60f0de86cc5a68614ec2cbdf8c5d7c5a5cf9ce272588b04db3883d1cd33a752afe468bfce551e9abf0b
-241 1 420 \\xfa348de0437f5a061d285182268a13419e998e3b9318f971f8b5305a047edfd6aafdd3075a62dd84eab199e393dc050164f68f5b048ad04fc941bd4d0f308b0f
-242 1 309 \\x049aa11bfbb8c2e676382c14c4c275b421d031c80d9c6a6f481f3ae2ab1f2b9f63785756fe51d694d57a813b8ddd0f8cb122874779789e033e4d6c8d61f0520b
-243 1 8 \\x34e6c3b4f96d3fc2d4151891edc8f9b3716a095a899a12ca044aa461f9dd79765317b15207442509c900f358921dd76e3ba84966874672f6c91ea841f827030b
-244 1 177 \\x435fb1985a8ad21c20a11df25e778507d71e03f23ec6e6e2dd4b5a763a9c9c18f44e48d8ff4d216c450d4c1f9ba0a2ea05f0c53493f453a96b4282422f34d505
-245 1 301 \\x37ad99f3c54140e3b2c1d822d7243129478f712cd62ca74b26a43eb76fd87b1b7d6691c7361259d5cbe81398cbcf2c7f9c55c1d713bf96a42da901d054d5db0d
-246 1 74 \\x8a2e12f43159071ea951f015786ca0d2a9e5576758442e3a11d374d403cff81ed8533f341ff5fb7d2c0e0df8f93b840b97d914373e9ad50790877ac7d9b9c008
-247 1 379 \\x0b29d74c0510d328146e8b5a64805a4afb10bd197b745636898d2c49dd4bac36465222aa92136007b21ad4cd276dc00b3fae02717d951f7bc67d196f2b3c1901
-248 1 30 \\x8bf9c6d1f60b6d43cd251416df0da7aefe4e3195bdbaaf0590fffc3bde570374d169016cc9272a45ee8475eee47670ba32bd28e31415bc200c3f58a407d3300a
-249 1 29 \\xda7e747c48334022f316ce36176cf92ff68ee60e14bfe0a6bc43455f1be856eab7f08b63553390adc88301641b82f39b0a0668436578cb9fa54147500e305401
-250 1 156 \\x79d78b5d63b02be1f1ef9b935313c5befcc5b4c37f693d6c370a5dd5c5518917044ee1c0f360ad7eb6b1efec1de6c9b4cc6451b7f7a84fc8c44ff9ab6a94c008
-251 1 227 \\xc70aa9451a0ea44a4291a43dc543d67b8fd993d30f73ca1ccc5eda6cd444bf3c1358fae586dd1b97f2a5df85fdce84490f3127274dce8bd630ab074c27573800
-252 1 415 \\x738f0d313f74bd20e2ea6af0c1fba5842286fe20f31583c01d680b4d71cff68e055d89e82888880c626d765683975c4fe5be8731cc3e42ee701df5c7221cc701
-253 1 150 \\xa8ca6e31bd36e6b7282bf44eaa9b967912503866fb2df331e0d33d2815fbdf7f124d368ddea1d1ed96feb030ae2b8ddc24707576e313a594cf36ff55061cd507
-254 1 316 \\x73215004788a5366da42d8dec4874790d72619b8f016881c84e920b08c089172d9f361c4a815a5e96a028f4322c09071bef09e09d6b213220238794d2c993a07
-255 1 200 \\x3a04987129d7516986823b04758fe7b81fb0d38ad49f03569af2abc7d3142505baf9ca0653728c893272fd05deda793b1185a07c579817b3d8d1d84b0468f10f
-256 1 371 \\xf9b93e84b02e65c0f832c6f3e2184bf46ebeffeea5ada72a7b430dc40761d3c3b5d688e39dc87fa31685b2a315378656702f048be0ed28b44dfab266c030900d
-257 1 172 \\xbaa3751c12662124c4793390afc97d7be8e1352b89a45af4bf364c8d2bfdd3e3e74e62563b9b7f03295b50a880f805e727d1751ba75b6ef16504bae071493504
-258 1 274 \\xcd9eac598ceb9cdc5e78408ef6b75c23c85a11c444efca30026ae7568715650750094f616f59f9833f54acb37a0d678beb584e9411c42cb70c9dbce27646b106
-259 1 165 \\xa141198d3550f8ade882da5662cb57e10fab99d248d2797abae38b1f902bc937a2e74ebc6b18e043a1a94af4eebe0392d04350501c981891f6c77554a4378309
-260 1 225 \\x4379dc18e8616ba3979b4ec16dc193a29ece3a3273272567f7c8a72bd61c79c4632aadcb96a2ac22648d369dab45606597f44c03d76d73042de034cb89654b0d
-261 1 413 \\xdfad9550783f86768b321eb704003936391f5c0a3852a24ee4e352b77bfbf281a85a4584fe4ed8ca499127baa849f6f6fa80bab23090884850e51ae33bfd6003
-262 1 13 \\x578d279dd0e1c17f28d4763f507a87f7b0e4fafbb71b59ccac7f9018e866ee5ec75d81b602a8f0008f8367cce4a7b1b738bf9376c11dcf667bcd5f679743b908
-263 1 251 \\xc4ec47345d3ab8ddbaf19ec83586a5e894cc71d86ba5ac4024c3d8ca2fb183128b4b6655e40d54a9bf84cdf17ce203b43c7ad49be856bc6025d1ca0c5d21eb07
-264 1 233 \\x0ade7fed2615a90762bf74aff07e37efa456da3a0c004d0b0e621971a0cae5094c68254e8e7121b52cc6f2d0d86151a641f36647abc09a95028a3141c0460f0b
-265 1 263 \\xb2d1d42d2fa777503e128c97279afd288ddce7c98bcf3b72998f44bb3c0a041c39c4e90c151f6f073d90b7e9d4f57d4c45746052f00e4d12ee4cfcb1d2542e0f
-266 1 132 \\x0345e5a6bda437f4de78b849a56ef530672134f42fa6cf9d675f7113a4b2b967309f51fb03f8ad5387134a7bb5588ee032e535dc767b17a86a33a0d1f12a5d0a
-267 1 411 \\x373e4b12038800058d6c4700b19bfdcbcaf289e4845e6aa168156e91a52555a4e4ca023dc23257f1160ed988a938f57b026fd8f1d05be7658c2296b83a581506
-268 1 33 \\xefef82dfcd5db9aa08a4c4675ffeff3b15eb596405f9d5c959e2e24e30316d23dbc4b3bfd7fd70cd6d4c591361ba3e867186b308a94b365492bc176d5b113808
-269 1 38 \\xe72f2f8189d1ca25cf30a3e945e6e93c7714489249c756c334c85804a9164d2e4bca2a8321ec761e431dc4fb48a4bef68ecf833e4112021940558c92f28a8b09
-270 1 9 \\x217062cb448c5d190f08e74bac9e8dd3554be12a6547c52966c6cd5bdfce47604fb8466533aff8d25f75cd7805ba142d5a9bfd87027ed561d684bc7efc943805
-271 1 334 \\xbc50238c6ceeabcd2d42c7199bf5c48d9eceb6e4d94c0e97cc81a4c8952f2cede76844eee7f6f4fcbb6be6e63e88154735ac102bc5e7c82e7f3fb1058117850f
-272 1 397 \\x52c69139765f39c7d7433e3a2ce1d8498c8e0c30a55a7045ec50c16131e67b2171924352f859dec76acfe51da03f5cc481cef3bcc0b97de1f170db53a6f02b0b
-273 1 337 \\x17fad236e34421912b28651558781fedae6aa84a444f982d3dad4317143dd405212e46027fdb32fa76efeef87884be3dfd930b54c111669a92685919f53d6808
-274 1 157 \\xa7334238f7464880b968aa39ecfe6510138a51bf04729cee6ba176ace86beb00f1230c5df7b868555696ff29ad97d6e830592c1a9b9ddc7920c5526992b33305
-275 1 112 \\x9c0eefdb305bca447790ed1bcfe39f70d689128d38b49d36f8a9e7705e98345a24ff4745b236447d20a66397b12677ab7e08bdb629e557362e140c0534dc3c00
-276 1 228 \\xdf59867ae90bd5a5110c321c00cef03c135e2e97c74351b9203fb8d9ad79f3680b46dea2a429ef3db4bcbed1cb54b3996a94a7ef0413bb635c08c821df7dcb02
-277 1 376 \\xf31811b3a95bcc49f92f6678d8bc6d4447c7d304b3f93210681f91240dc9af16a6c278ec78236e12a79bc903b3f437680ceae77c750390595503bd9002c6d30c
-278 1 332 \\x9ccf957482194232bf9bc36d988ac1ee70dbd9e9c559ab4b783b2a10366addebf61993174a0e92c3bcc32ec1af3a5ffc2f3f95e5beac68930ae26673132c2b08
-279 1 17 \\x7ebee3da4f6f69fd1e1fcca2922a078c89cc07d45e2268c118a11210c52e3fd02ebe5f6ad7f0968d8b776fd49d200a9aaf23db154eccbe74f4bb7ee35e5e5e0c
-280 1 203 \\xa8e321f00459d0b033aa11b68cc87f8dbd6f6bcec46e8e7cd0b88e4fc960721bbcc99adeccccc63bdfc4486066dc6672a567cedec62a01bd1870ee20a5059e01
-281 1 89 \\x517045dcaaf0e0b1d93dfb9d407d8224af2bbf33868d6a801a2abd4f4c65cf0646406383322f32e11f60c1b236d291f747621ad27ee24916eae85bbc54025609
-282 1 269 \\xd1a4ae86205be103d4edd4dbcadb445e7fa1d2f1e8e518ac337e9e857ed5367ea54f85054b160b77c54340434abb575fd0c76e5c925e0950f53600e730e6b508
-283 1 361 \\x3600a10e49a51796548b7b159d95fc9b3ccc1aeaf9401f223ff3792cd0c0813e278c6daa14cbec0c0374a6554c08b44b5a88040c05c066d2744b44dc8180fa00
-284 1 87 \\xbaf8396084435e259ecd58f77dc48fcc20303b25afcee1519bd2706ec10a27dfa18679312ff430f387c0a1adc5efa4f9365a58b1af9ca506df8d25d12b574c0d
-285 1 387 \\x3bd319adf8f1cf77a785d073783a6a2356d8bafac8c329901e53f99485e92eb4de2622a31904dc1a6a63b13f96476ee2392fd547fa5c050e01db60bc71725303
-286 1 25 \\xd3e9fd99c738a5ad949cb54e3200e4b4da5a8aea4886f4301fc9d095e2a402cff18a012ec5ad6c94dcf3aaa76a69d9c2c27dfb64858a9745ec8e7747521edf02
-287 1 4 \\x733be87dd89b9e4191cca7d211e1bdb0bac335b3012d85eafcfb259da7714934f82a446963d0e47e4fd9b618c3d4779c1fce156ccef20f9691b41f0c88662800
-288 1 84 \\x2ef3a87dd7aaf70646f7d3d29a76638c93ee44ee9e8efbf3cf3e5056b36bc105a2fafbfc73f4f5edafc3b6e651dc090e1c45b48a111e40fc5a044cc3e36fbd08
-289 1 404 \\xa7d25985b3ce59d2f5ca4333b724eab4d837f9ed11d2ff4a46aee9e835e1f5f7d157e403440f88b4d441ac5538b097bdfe7488367cfae6ee12e9a86e3681250f
-290 1 57 \\x7dd8036ce8f4ab6ce68cfa1e7243aab5e56c5c3484de11b52d0aa31afb6a4adcb53d79fab324f70afe176a82f70471ba6e4c45ca04ae65d0ddb4781f26a6da05
-291 1 322 \\xc5925a902f7c64f81107b3bd3951f9148defad75eed5b4caa12f578798a7c15f6e33299f1d387652c8e3e26478169fbc8fe2ffc3f6ea0ee82b9a7349aa048f05
-292 1 374 \\x84e2014c687ab11daa84a8282572ad504bef78d52565cfabdc3e4eb3d950e51dac22d42871c725d5a813509a10732b25b869729e88adc59f8ef11c2d17df2c02
-293 1 18 \\xf83a6654e844e441ec4ca8166d5ece4377f8cae37b002b8f82cd7e9f0b30966df628229a784e1e976f4de5d4b353ccf19ae8f6967bd99ddbf9992140d1b9190f
-294 1 105 \\xb34d961be21668d823b572b211d38ab4d363e11f14d13e5e2d254115d10d3844d13e4bb161d38fc11a5d6d1dddfc0d91d747fc76cc1bcf60e838d4d6a63c2c05
-295 1 317 \\x51bb00e7b1e5ede29e89c7fcd498f7958002e254d88628f84b689a94dc9fe30629f7005499877a247db4ee384352cfdeadb959e20b73250cafed9c9c984a3402
-296 1 393 \\xb895658a2c52c72afbf616f433ea328ead8f09ed586754918640ece30877e995df17ff68515a7ca44efe5df641c8708e64964662c3609434dfbc8caac6674f0c
-297 1 253 \\x0892c3d3113070b1dd7240df49738bd8154b4d9e12f154e186e3430b93eb83b2641d1bbee87ec98f55015ee71c565fa562d008f925d4e9268f67406f94b18d08
-298 1 388 \\xe3b21162cef98f1d91ed415e91a920ee0a7e1347cfdeaa1df594b93ee857791e61a1dbe4cb0b385fecbe37996c1c175ea606fa2e207f7c57586473dff6cff605
-299 1 161 \\x05db586d73bbcd2518451ea82c0a045e973d7f626d0b2c6540f80fda8006a54a56baa6d5ff136527cdde0b25dcec5a07d259e64a43348b2ec7f0fec6c3e96409
-300 1 162 \\x67de9255d89da7de9d06efdc56a9aed861e2cd339790160857855980e03ce022d5fa2fe639fc22cb9eca02af4dfa3441f55bc80490296299464b9c3ac66f7109
-301 1 67 \\x9ee8df7ca82564c02eca64da70e57b3f40de42c4a79b16419f36de88521faf7f9fabf0b8932985f736c47d0d8d0795cb628b32079bbdb982be5a47e440553205
-302 1 215 \\x2b1ffadf486413207348b6ad363e6536a2c00abf45b512f8bf4bd318b8c7d715fc0687dec93aeca99a4d3a19ea43f01e70904c1b8caf4d4080794fedd975fe00
-303 1 115 \\x5c0b1c38c1c41f7b51f7ea607310897425b0a5e704413695fe3ee9b06f170918f8034e05609c1ace25244f718731b3329baa99e698e6213c4811fa7a6c6acc09
-304 1 148 \\x04f2b60ed5c21c07eb8c3a7886618d1e508886507ba022bac991cb792a8f02c228a9e4f42dd5a97d9994b815a7adf7243765bd81784f12860c820d9dd0baf50b
-305 1 366 \\xae4120ff8470b19714a00d7b5184ffc95fa346443fffefbdf4043316100f27757f5fc3bb61b7e068041eb14a5a30df5ee1cdac8333dcef5dd8ef423dafe86e03
-306 1 303 \\xfcc7027ed22318dc80a47d14a433153692d1ffbf567cea6e96f737dfda0095c15a9b928d59f4532a02c58e335c9d0a1859e6e5a2095e0ce7a37c2e7a2aafe808
-307 1 285 \\xd90cb290dea23952abf26e1ef2b0394f20a9f12568ffeb077bac6bcbb08bcc363e75ded464cd6a5ff14b63d8496f795d3adf959af2fe26f69e3299cd6c992e08
-308 1 298 \\xbd945c90490816d5255d243c9f9b16108be5bc7550a17e378ef814a1018d27c14917d4135c5a2c0c2c5fd224e4c24610659bc80b6d61f4c79548ddd772932308
-309 1 42 \\xa6eee96f03ddc8f8db1b370126b68056a08b6b42c43b62cdd16207128dca1d59e9f34b5335216de4565e7c85656e0f73740c24ff1db0a2f6be62ce22832f3f01
-310 1 352 \\x980012ebfafee2225fcbb9a748a3bbfd013328225deb29ab69abca83195f6e291d7848b53e7c3a064b789c915eedb9dfd223f7c713b977bed84c70cc1fac160d
-311 1 336 \\x7b1e3c7221880e9f31c65117c2014279d7c46aa2a80d055eb5fde8f96bd9914e263044755c17b23a1b5a8b3d5c5438f42b7d6b62ca0ac3b47c65bd32dfdcb802
-312 1 145 \\x18585ce6251f2bbc1e71a64573d61cc9ef0b0af3e3c7d211a61170d4b979bae701e1f5713c578f402cc1a66a84ae3b30bc0713e4148e6144c4e7827ba8472b04
-313 1 73 \\x96cbf5ed12d010dcb06ed9700961cb871311557c3e54b8722fa06bca56452edbc03129d3b604254f52b5c07eb8d89fb8dd2dd608250d91fc1616e16048b7fc08
-314 1 64 \\xab233c31e8bb5fa38a5bca092e5c2fdbe02566fe9d777bb39d1cddff33fd6402fc8887ff071f5c8f53fc182d3085df6a0e8b6410d511566238fa0dc239a32a03
-315 1 192 \\xbf2e8b5e626ba9fd364bee10b375b8ba1d1d7f9061ffd1c17f6fc3187abb8c20446bb9fa3c677dc0ad23f80457c6849b92b9e358456707343628838367a1ad00
-316 1 416 \\x8de4a8595eb78b71d293db6d435e9be747d0fe11927d898c39a9320e3f2f48fcabc59b3fac250d43768dd9d20641ad66c2f31f177a82109229e582432f7f480c
-317 1 40 \\x1890f8461a2af155fd757506096405f5bc00c222b548db2ebbdf31823fede6e493a3e8813dd93cd758cff384aa18a0736e6c20a6b2154c5e2c53038bc6aece09
-318 1 134 \\x6ab574e2a865b9da5eb7767427e3f5baa8dbc0945216a16d21e071e1c9da9828637ec5778d9bc33bfed333e7a7142b9706146433f38c2c5ced9534197c83800a
-319 1 189 \\x19cfbab4f6fbb279d89ebb71a5a15bcdc2b616d99dd2018d66cc05461f5b2539f0034433eca6f5eb9a9f2a1dac5fab054e642e902c3d085e821bffc27947ba02
-320 1 419 \\xb7391a4f4f7bef81058e2551e90574c8bb92ccf203527e88951c4d0985c8207982206b5a6a302f40645d5c6df46c9157cc0f3841415c7ae557a4ec9704ad9d01
-321 1 117 \\x9b9f08f8f0c3dea7c746166eaa542e29edf612e5ee2809152ba59413c297119e2e8b6e5245101bf29d69235462c991271433c166457a581baa2c2d2cbca39e0f
-322 1 191 \\x5f8756e68133d457a99aba6c4b72e80d525834a375d22e082347e2cf2289370e4dd3a677a9ad713cb1d6ca0f2c9540ab7e35dc4b622276bcdade17380f4dd404
-323 1 11 \\xef2466d552c1c2d5ce5d6a9de4cacfe32c3489f5fdb7d0d619e4d9643bd54cea3261767c5ea9022b80a5b6514eea775109b5da962f2dfba35617cc1adb063c0b
-324 1 181 \\x208d9fd9a031c8a1c8e65128f4be394b5ab8b4e4ab18e2b0a7e15d9716b35805a74579cd70ba7b30df2d0baf16bfb149834658e3f23b7831696b8552b2785000
-325 1 238 \\x1c9441a57a0a1aee1fa387a097300a8a8908aa5822f463b3f8ea033dff4b7fefe4ae92cf39bbe44bddd96fb57d01330144db4ba373e9162c3da5ab31b8562c04
-326 1 230 \\xeed11a34ac313a47e94aaf2e7d5933f2a1c511d797a948f9c5b292f28a3db57a58b2c5a476f9aa7ea10c2e9a6a6fa4c9c69fc5c6ce1fb8597309557e573f2901
-327 1 220 \\x85ad685335f2ac95b702aaa3f23817fe602a248dc31a675a996a8002eff4b788a83a4ea87d20692368e380a492242b91de2db5f6ff015181835629bdbea08e0e
-328 1 351 \\x4db51d786c390ae2fa4b771f84d0cbeca7b21f394c1db53cabe65792ebe657b6f007b2ed9a67934a0b54d80404446a8e77b80e71d0c62854009c6123843cfa0e
-329 1 211 \\xe0f164a8ccac13fc116c6661a72a5ac50d80495cc9fafde3728c0d1a55e9ee93e671d9d2003a9b036ddac28f6d8ee90058ea2de957953818828bc82dcfbfb400
-330 1 410 \\x9fae7383508efc7357892597023ae5c6d49d413db28c5cfdf9f22f3f43eb50b74e2b5854f7c86f1873f8febcf7b7296952612d21e5182931dd4ab770556b6608
-331 1 236 \\x0b04bba0ff62b1aa216fbbf798f23c744f86165c75b751b87ed48f688a1cf8259b434fcba40d4869bc090cff65a13173a0018557aa2fb595cf9ad6c483274204
-332 1 364 \\x755c93b4dea032be838e3c7d88fa2c2a6fb0b367e08b899122c7050f9980c2911b195aefe586a1adef8500769b540e711a3f93ef03df54311e2578f9f39d170d
-333 1 331 \\xe3ee8154494ffad6162105c39eb2ccc271609d29b860a25eed11fcca09f14643daf62226711daf446248e918e9243aa6be4a454ab652403d899ebb5b7de4fd04
-334 1 54 \\xf56e002298502cad46322119dabd8b6ae6ba01dda6450aa106512f76095d027471d2cde26abff21d5591c6da79b66aefd0115c37738b9d8a3725024ea8518c0c
-335 1 223 \\x65bee5aeb583f2227bc6bd73ddf5435d38ffc3f441e8ba342ae79248803f5759b2e81fb0cecf4b3b1bb641bd6e9ce223cb3a89d318a9bf6ec51b65d4ceed3707
-336 1 296 \\x5abc5e0c7fcc6a03cb46d013204236842f8351d306f78f4ed59ad817aeadc06c2af05f70fbc357583bfdb0b68eb474e09fadbdd3651c18a1b061d4748297eb0b
-337 1 45 \\x4c0a8bbc25ad91c57cce265a8180998d60bb5d93e09813d03ada93e39c5b85690f758a87bde747483c211a6897e0bf9818c35c1bef21e6387036f01f6e32900a
-338 1 123 \\xd22eaa15669508b3eb37a0bf1597c1a7fed39bb3be8c7c48e6ca5788361cdbf5084609f6dd64bc67344508d880da3622362e6e4de11e3c81e87dbe64f8b7fe0f
-339 1 27 \\x5cfef5fb0cbcfa1412500bcc0d58e872058734ea0a7005dad3e4812399066e54b71c949e02279bfd907f4f496672b19d7ea6c278a81c927bb3c74467e6cad80a
-340 1 107 \\xfe7b81d8148a2e7b4cd6fd2d3d5493a0edf4573caf86ee077579b94c878cd70a951b223825b892ffc5c93778e232f64965236c7d6db1567dc87bbc71e3856000
-341 1 323 \\x12fa01c1c6d1a6a1ad13f9aa830f33499b24c997b32d3264c5028d223a4056b18c477133fb49c00a3d931c55f7ae4d00095d8a8f6609a703b7a79c78cddb080f
-342 1 402 \\xa7d18aa9554820608cf3f73b5760bafda34b52c6ec84980f626415a6e1bd7ee34501d378a9377743b1a71878ef69cdcd39077154f4183e26c4adcb4d01867d08
-343 1 239 \\x55a9e6b0c13c0eb8b5bd2e73a940c986525710ce69055e9dd435e134e3dd9fa1f7277a1497339be45889023b1bbea1aaa48aa8fa2e78c4578106809d9400d607
-344 1 96 \\x1fb7ba1573b41668660ed96262c6470af65a275264073dac1c0626989f0b6313a48e66254f898d40679aa3c7c3ff05d1154dde0394387d2e54e64ada878f2906
-345 1 2 \\x23f22822e1ea07a4f603039b59622c092dbedabeabf1c658239943b501fda5b1fb43acdcb522a6663ab0787fa9a02332447b17a98e9e5c8f8ab6577868182307
-346 1 24 \\xb3a8bfcf3baa514892441af8609d77f105bdef55d2e2c5428bd7e17609c56c4ef1e336195a10ecae982c0cc0e0250b117e198d92663792473bb0c50ce66cc00d
-347 1 257 \\x4239818442ccb487e2a0ac66d8dfdeb999a9c6b8b26935ddeeb8f4f5bd2bd1b61758ae89e018187ab6139256798ecb3f879eeefde07d7f0de4c04deb75c7ba07
-348 1 321 \\xdabce0317a3ac679e6f44516c6123f2072b599af60d3398c2d2cd0cb4ed77c652b06edc24b1859ce72ecb7146b892742fc9fff592145717d3cbfeb107e52830a
-349 1 300 \\x533f3ff1da3d0d14482f3faa17bb583b168bc79f28056a350a614c1923a796d4a7e9a9e502a6823313a88009d1026ded1c043946ce4b490beb89c15c66a00702
-350 1 277 \\xa94307597dc9018f083fe97f1753c99565b833dcbd6d4c3d8e777421dca5c8bc77d6d100a62712a41851e173113cc7b716d39df5facd90fc4d5d0c7df90ec104
-351 1 10 \\x9d161a67015541222c4071f6188f4093053265524d271e1172013b0bbb8dab6cf5c92c134de036a74cf83a4cce6f75dd4400cc8fa182245913beeb5cc37fed0a
-352 1 302 \\x1881023e1537d90e157569efd0af558e761ce1648880f49a3d922def30a178ac534f6f247a215aa19a316fa0d8a222d024b019bec0d06d38506fcb88b0393c08
-353 1 104 \\xb834f7345ae4c392333fc47ca5f5d6ae31ce3e56d47f8b6083a15b0850ee449d839ea85b64ac9ed91a1d46041218797a7842816aa2067c9e618afae82323d206
-354 1 405 \\x3e390f072a093d41c18fe1c7efb622b7e84a28e6638affcac3e33ac76d6f31ca569a98b86c82609180ba821b579a51d411cbfd87561dba1d0744b8e06356bd09
-355 1 118 \\x634335dd5ceeca77cb729fea1676965bf2d52d5839529c44a434f50680ee66995b220f39165b8e545df2434d8089093940b6ed4c5ab48011623af8f6d970230a
-356 1 196 \\x9e4a54692e6ede51917afb517bcf60fe74f78fc060ceb6ead202437209cb1e892dd1af4fda466658b4acfabdc9a55c8cbacdef7b36a66735f0e0d4cf501ce50f
-357 1 62 \\x69b9dc231975414f17b6fd7cecf41b3e3acca0760b084be02c32facc92e72af17ddf3e2ca437ed6b79d5b4b77a4a5c09391cff0ffe36e80d797dafb126e2410c
-358 1 262 \\x59cc3d25dff113fa2e08a7f3e36361062e84769f530e02be69628f60d2d7e49046aeb987bfa95d76181fda82b7d36452aad05bc59e1251455d61661299201f04
-359 1 326 \\x107d78aaf90caf7fad54a74cc7c6a573d493f54b0f17a7db777d62793f9317001c7ce3ab1a6d6f91bda4c6226aa4be54d2599c4e7393c90c3d8c49fa9f961d0f
-360 1 53 \\x0f19f71c4251f947b03b728a473528f081e590691cf02502b89dc5d3fd65d489eab646568cc3c3bbfa1a0b009963f8f960825f10c6f498195ae7690e6054a90b
-361 1 65 \\xf76d8147877a09e6977de5d1652cb994b032677657318a632f38b2de88a2ba6046fe59cadb5c763030a270aaa8c9f9cead55a6d2204830fcc3608395f7e0cd0c
-362 1 122 \\x2f2b1d2066d817c4abaaf7576dd532012f3dfa20dcc2b040c8907cbd674eafe66fda07ec8771f6beb964c3f3adaa945187c36db6f95498d2d695fccc7e948304
-363 1 143 \\x3ac694097ca07976e0b6ccfe532cd71aa92557e5b594d520c14f840ad52cbd794f440bc24ef1ca71781e67a1d0967486a308af9abb1db202f37b6059e9dbec09
-364 1 195 \\xe6ebfe0057979a23bc329ccce6f07658945d59e96e18306648c6b9e3b8d1559aed437f06034438be3ac1cd93b016c017b196bd8dcce968d9ba3b5eefa5c8dd04
-365 1 252 \\x2df7ed340ff92c413ea21c9ec86457c8801ea4dfb21731c5bc5a5a648854b9bdee03744a108d39196b8b468124b3cb9acd1f02e0e7fd0c2edb666fc2baeadd0d
-366 1 423 \\xedfc5538c66a385bfcab5af03392448af9657c38821721880f637aeaa64d5eedf2f1e65d55417b5173d7b9828fe4b2b56c662d1fdbe9372dcedcec16b80d3006
-367 1 171 \\x924902b9500b56b6a0c527da60083e2ec74f59bde574c6f2c6ae58689798e5ac7ecd055c6b45961ec2581534bd0e6ec72174d55896bd06688621c78d56537d0e
-368 1 194 \\x3b964f7661369a4ea4c5569437921fccb9aaae4e6b6a7c829826bc6114e0077144104df850d0314724c83eccd8cf1b15ba608acb3dbcbc05e16a1732667b190f
-369 1 106 \\x35021c88336c56d0fc37cd715e924bffe32f0e0a5062a34813b7b619d2bad112cd42d61a722c1619c5e52b5f9e4472041c726bd623390f6338aeac7b2a145303
-370 1 240 \\xfef01ad42f73ac076bfa865e0fc7235a9ed196c7344d750c2c9ea2143e515cc104aa26edb3af92715ed4526a29229b92681f00356f6d7cd8597bd26137aa8306
-371 1 295 \\xfb6a1e489acb6691323f7a77b7f14127e3ef6c6dc834125b1c2058e69d7249f323f5a1ea0fa450c1572c95cafe89c154ade9ddb72dfaa01752bccdc54b97f009
-372 1 294 \\x9684ca7fd5f949ae7363b61280c1b0a6968fb7ea536f7165da5c995b029bcfce9b0f5af1ed248bd6f3e85907e2551ec3a00939876d662d3d2b494fd97f8f7400
-373 1 287 \\x722521423a8e59bf7d61322b589c4f5db9f74cf3c56f5119110e0f414a7fcaebd716747a8356103d43c25992d317a57d4fdde798cfcaae57e801b4cd93404c0a
-374 1 47 \\x8e6f71098368addb6a59e54f9b6ab2ec79970db85ff3705dfc4bfbc327ea446ebadebbdada54faf4e53c3a45c018fa87abc7319b2848eb8805f550d86c99e605
-375 1 175 \\x7c96b91f8c34cb3648316f76df3fd090a8c9813747e07667bfda2e5e9fa9364083994e7e157a6cbaa5ac6ad1023fb41f3da52532a583897b11aa0e8a4c85550d
-376 1 212 \\xfad1a550328005ac76cfa9a57edc01f3b1ec080958d52614de1b2fd15ae6f5b67c7dc419f72901446ab80488589560078dffe37bfd5d6c916d3a86f6399fff01
-377 1 289 \\xdd7f4ca7a5c9042b0c8f1f767d68b087fa60cee188e4d9ad08d138a5cd670676f9171a4e20429f75c410347904ba6404c879c6b0c3b05c7bf45b8f0a21c9a101
-378 1 292 \\xa6cd5d2d2d9718b9bbc9c1c8a45eb88140c1ec4a3fa6a746a60a204224360197a79442fec5a231c1e761c79256affc46a6a10e1b2a368b54749693df47542107
-379 1 312 \\xd383994bbdf96ed9f1774aaa4d64daa628428d795ba3fbd9d88633a1d9ef39cbd04e97a9d11a4dcda4041a08a82ded2c02244591e837d8d1bd8d67e82b13110b
-380 1 179 \\x84cfd3fe1b426d0d460fdfb0d8014bf2b0902e4c61d9cd9c138a70d0ff542f44019ee490a500ec490c6bbb82bf484bf75827e1a625fe9be7451634441295d502
-381 1 344 \\x8c217d2fc69ab8c19af09414fd1e2b26ffce4a71d0004801c8626bfd1c7f42ca8061b4ac367de48cf6d292105b88bcb31b4e0603290c363e04090568a3f81d06
-382 1 101 \\x3087ff643cbfc973a6891f5ee6bcb907b3d96de97347d2424f63d5358b9dada8b413293673be025e871a641623e9fafb995d66be4dff47c76d33a0f302ec2805
-383 1 308 \\xc966507e93321ccdf771239d9ed207d83ceab3b3e7e1ef9118502ba1e2f766b07ad7cbf86d519be434bbfa66cd576b8235d3f8ba7344af10f28bee5a69ef4706
-384 1 16 \\x981408e0c00b71b219d3c51017598afae6cde6d115ea437e7408af59abadfb5275274108ecab6a37e0849590539089cefa7d2ddf5f4e40013713a9352df9f20c
-385 1 414 \\xd1f23f520ddcc7879be216e6dcf5f3dd2b104ac1e765f99f9f2c0dd634a2f4c7b264ab288cbe3b0a663eb31105b54d6fc54e709f6f6c873aae3d3688512edd0c
-386 1 108 \\x6325bd3cf677c9f5fe367dc5ccf8894ae4f0f6369c7a1fa324056f494a82d449a34ff35f2fc5efc36e636fe4fc7f2f0d71035f8a7b03c6d4fe5c3e0f112dd809
-387 1 137 \\x53de69a80cf0c888a0c55f877f4d0438ac3a2b36628987bd87b51ed6b7a5b408572af9499fb4e68c9c2aad3d36d9d8028676fb17d2c7b07953eb0ac77c54fe0a
-388 1 392 \\x34bc5d1ff16da69dee1bccaf5641c2e650d83696b77331f8f6bb7bd91e1807e7f63d20e529122f17a12c5d0e47de99d6db26df1a46c6dc6360bef26ee9254008
-389 1 21 \\x128533919b72e89875982f86c61f259d7094962f08cd1d5b4b31c489ad6d3d5cf9730ef2628b9e286d3d3813a72b8c8335757a2760d7eb7d37ef710d6067100a
-390 1 82 \\xcb3c96972ed7a2fe88b332f7cd865167cd0a6069da127ef8cac35d82fec71a095ec0e8f06c35defe77cb6d6892f22bb0d8f6c2653f8ab982893eb3deeed27a0c
-391 1 167 \\xe244561322acd518cc992000a2c05f0c1d57d740e30b144062072b6a4be81f9a1d7ec1e3ba1969e32a6319bab5747908a433b739021f418682a95fd4448a900a
-392 1 373 \\x7ac41422b7a8c5b001c6939ac8a60dbe8ce32459a82b9689de3c8b90a5797f75029860ecdd0c313b54b8adf85bac73784469a7fe923ab2412657c5452e111402
-393 1 168 \\xa661acb6a797a6f20f119be78bbd30d3ef8ac64173b51adb693696d499c5d69990b8ab0b145e650cbfe56ea4836408929ef30fe17b1fd1f50681a770ca24070f
-394 1 210 \\x3567c2b2ff8f3efb224d4279802215d301e5e4a913ef7cbb4a1a6afdd43efef48bcb6f74e3797f34f6ca8407b4c197be017dd8903b49e1ed631199dd66615b08
-395 1 102 \\x2ba68a140a3b8b4998461183bd4b468d7b8c7c6896ba47bd4392134f5ad62a84404e49264f577fc439c7e465d0f1136d35e209a3940be8b4d755f09bfa8d7803
-396 1 97 \\xdce0a094ca22d48f14281445b3980c7335e793d6a89abecaf2ea89528db85bafc7e2283c764413acaae049ac88661de93fcb5c93d4b61a4cddc6cc2ff299170c
-397 1 245 \\x13cd6af0df761690faffc8a21c9094fb620bc5daffab47d8be75fa020f11eb9dfb17721d240e5edf08cfe91d9e327ceb548bc2da76a7c5ce10a6e2aa5ea63109
-398 1 91 \\xd5e8a31d63f0feca8945104212e5c67fa5db174c978b161bb35d134fcd1a402fbdc8608c31654a52e649410524e8527dd07e7b98942b25d7e7161931d8aeee09
-399 1 36 \\x51f5aa6ab78edd9c12b4c97a2f053a2eb8be2f69b1d4de74c49128d98b63ba51969d6d19ef0182fbf47af942538f4298638cc5dd91ecfb6b752c1db79bab650d
-400 1 394 \\x1d5dd9d83faa72c559f59028cf3af5def024ed4cc4c46f16725b58e431e0b62882200d1a96fe66a9281778e704941c8704c518fde63d6020fe3f671c2479990b
-401 1 391 \\xdd66655f02adc6bc627f7cb5cef6ee2fd0f08fc30909714c696bdc72c47553b5e1f2f07184c87bc62094f4ea134c0de2fcc84c334a0c3c12ad958ce2220ed604
-402 1 139 \\x884bc1d4264d572a2b368d3f0bedecc2c179cb31732c4cd57855d9e2c87e4393ea26c20949d96560992f402fac046b687a8f36cc4a900fef2107f80c1864a002
-403 1 180 \\x1d2f646c8222fbabb71f216758f9fa3f36aa8852bf99ed232aabd3d30012cbc162b9b7163c2cb3431437a8ebe40548c0bd89ad92d13ae75be330d81b4e2fb80a
-404 1 19 \\x7c0e6380ca6d1731f88de25e54f239de7724f37ff242e206c485642ac9b4f6c894ba5147b6f8784d4aa51b1f929cb0b91101ff4b43fb480175ed2c918b193502
-405 1 51 \\xae999003a917a0dd422affe49d069a9419f562b8ee27768949e0d9be264c6b0cab164a6ad0c2bb239d66814bf2daa31907eba5a3e767ea161c5dd4008ad99504
-406 1 160 \\x548258ec2baeb50e12fa6b26c810da1825e2147c15aecfecc5ea960344f919d4b646fcfd3013e78b157c4776c0013f985256d9018aba870be6c67b14b66c9609
-407 1 346 \\x27c3844b6c9f20b10aea5e868de11b2327b6befd4b47a738b88fedfc610564ff3d6c1f9cb0bf91c475aafd98a21d83ddb1b5c6edc3f2f24722fa0885626ef70f
-408 1 83 \\xd3bbbec9b86ffc3e25b210c47de30871d1182c7d97407c9e2fe3340336dc4312f9623ac5079ea162076067c3126c0b17385e0f02d259fb64eacd035c8de8f306
-409 1 221 \\xf2369ade84a0f0f25f3d24f651d23af25ca05a4ec608d99bd5092e2dadb7f22a195ae85cf5dc2cfdeeb26cc880079b9cc2e6740175a1f86c95a06dbc5a65690d
-410 1 6 \\x65d8668c9be7444cc4e4fd64613b130df37e878fd334762b396262ad224300ab004a011cc91210b757e55d55705d7a80020e6513e03a7a9c5e039a518578d80b
-411 1 193 \\x254b4238ff290712c89382c1379ff2f12243df5073950ac8eaf54c44a7ad05917dd769d5ce5d2f3bc9893657b22094721bb4174a254f9592581d6a707abc4c07
-412 1 198 \\x81070ab4eae5d7c103262c85323fd3ba1135d144d4b901cf278c83c6072685081869ae198ca906642f1d822d19b546cfb4ec27a93d1c5684d47ac96be88d9402
-413 1 125 \\x31b591b487f71f9b7cf8efc2becec1ddc1c05de2eb0f96061ebfc3823ce2bf1f85d584b7cb0d064a8d3e94a42147408670d224f7b4632a31cd5563fc56ca4600
-414 1 304 \\xe79f386725756f92821083d54be464fbd2cd3eba456b7b36fa0a0a28e63e4bac9fab0dd7f79d8a41af7c2459884a76f120d55c6c6c9ebfabd8f29c76d730eb0c
-415 1 128 \\xfc4531684d7050c38c4d074f06aa06cc94bf9b2b6026cf373fe7e07da911e562204d00312b647821a1d951f5b5b4fda36f19e92f56fb04382ad6a36108d6d702
-416 1 72 \\x438808da9af8a20fd365123712a39adeb46668cbfceeb422c6359cedae241fbc915710a8b8febfc454d97d8a49660486c2857092e6c3b443e403e819ee89e608
-417 1 224 \\xae56843ac3a631d122fcdeeb5d345cf9e9a75b5833dc8efb39702922721f01ef44e218eec7f0b26f7ddbced1ad17e12adf46d3cea39d5fe15c2fa1a5dc442808
-418 1 335 \\xac92970e073ddedce5a006c658cdcc69887a7cffe332ad29273c593a1b57d82a78a1929a3289dd11e5ece60868223dc9b2d1b471c1ec2f31539290cecbc9040d
-419 1 158 \\x771d2061561fe89beeebc4f9b0d9fae4538e83dd18a4dde0592e45699cd8bc78b6bd6fa6a50fb2d4ae633b536a9d99eb613a0bc46736b5db968e758647e27d05
-420 1 268 \\xa9d7266e4b1130e5dff3b0d5b6bc522a578d6aa0832ddb5750fc3647e7e4c610e6187505cf1580cbd6e064d9f91cd0d410caac0f1038dd0b5b01c5c228886a08
-421 1 368 \\xaf0ce8d5447930e8cfa8064bc2d9f6a6277eab0f5f7171509323fd827ebaf15e119215b0336be809829a9a34aebe8922b1e322de816e2012543e78f4875dee0a
-422 1 155 \\x2f2bc03e7437b75ba49f998e8377d19fb09b96b46ef5a3938d5bf7d878ad66cf1c1ac18e58fe64c47feb2506a08669aaf607de47797798739ef4bd47408c7408
-423 1 256 \\xd25f64e96cab7fac9156ee931370f9877b39add82a43a9fc47de16abb0a573fd9b76f365c3e4fbde95f98cc340ecac48e943b1eeb93c7471de2b3f0fb4571e0f
-424 1 116 \\x0c90ebc4cdb40485e09158610b651c25af9ea4958b8d57a8d4d6c9dfcbc71db7d83d1ab42200a21c24325a116549b12b0facfe819ec5d04da05bc38b9a7abe0b
+1 1 81 \\x5e2ae1c64a2c1a432404d23c3041845d1031c6898893ae0233b2788c18ed1736690774c83669fcc8020229245aa700b4c94cc3841eae15545bf1ebbc38c74003
+2 1 225 \\xadad8526f9cafdf8cbd600e63987ef4c3b70b27891c25013df07524988b9b6aa32c50ba6ca8b2372f33c07579c876bae93ad3f50e39ebf7286b36e426e2c0903
+3 1 96 \\xb524870268d6946cf49c3458e1764b82666ee7f11afe519ef5f1281fb9176e89cea68fad579c1ca40019803b6bdf5b3ddb0f6b491179e3e9f51060ff44599a0f
+4 1 126 \\x99ab1fa3ac26bc637972de6845e8f72e0342a5db99dc75aa2c27e39616408f16b19cecbf796aa430dfbe2b87d582a87ffe8e754f1a4f3037cc9a2ba84928960b
+5 1 245 \\x7e3bb08189693d75009a3133405deb2ed97f092c70f223bb78d982881cd3739cdff2d21b8f1e60645ec2ee7fbf479ff0246d9c8db535984301da6e00af8f650d
+6 1 110 \\x721e44c6b056c380bbe22b668a5799ab3769d60b41e3aca864b09765c6da9d28b710689d6d82841123d932282f10227f247e4d2c2c9904cbe5038fe4925cfb0d
+7 1 324 \\x0672a28f9aa91962acf0c190b4ab167a4fa88616475247171d1a547e62261490bb9a995091d241387a326089bf7b5abb92ae74954f58fa36cd870207418fbc0f
+8 1 121 \\x5145ecdc0f55d97a7e133b394303afc55f665a9ec1ed318fca6b4e5e69dbcbba4e5b9a28faa20cf832f621b5a1eee1407ea470d159a99845995e90e8d49bf603
+9 1 200 \\x7c22cf64e19192d254c16b46323fcd36b265fe6161687c2414cf99c26b77a02c984defb9dd2addbbc509ddb398f92856bdb9b5b9e3c89c1cd4652205f31faf0b
+10 1 224 \\xb1d0036178e1fa74eaab101e2ccf44c07e0a69758c8dff16fbb5a85dcda18a246fa5d1f894af7f184f9ef930ce4bdbc325437386f883d01ea7dab6403b10470d
+11 1 244 \\x535b0e8a20b20b8adf1fb7ec0f1ad611cd0c6f8f0f1bbbd739451976e2b7a7e4bbe903e09bf1d286efa2e4208d1a2c68b3d70896692c68b7f45138fb0e88d00d
+12 1 170 \\x2a70764ea0889074b13da192230af5e9a6cf4fbc7e28e3acf2672b594c6075099cb01dd99fcbb8dbfe72f07193ec3e3619928a9095d1c6970807c1fab0798c05
+13 1 364 \\xcddcf82bce96d8f20e00beb30dde66c827719915e45f68003c442bb000fb215db4534dd7bd0229cdc498297b56492eb512ce3d0b850d874f5a37ecfdb3cec405
+14 1 23 \\x556a61324a8f57155988c25c1b02bad03bbb5b2f396e430effde1f006c3da8d256f7020e4e8f081924366f9021a375f2054699d8f66503dae7d287fe9847b308
+15 1 67 \\xf28085a47106339be3ffd9421a39866b58a2f34acddf869a88fe38df002c6a83a82ed757665ffbd63779df16c8801fe2e7ff6988c8d28237a7339bb4974e980f
+16 1 74 \\x75e9d9d51228135f7208f1a7a77d3c66e0b29876d9ff3861cb6e1f4586f54528d96172d35c0e567913313169b90ec2e050af1343db2596bf254c030cdd9dd003
+17 1 33 \\x468966d06412dff760ba704148d346b4d9286646b157fd0859d6dafc5e82f37ac587c549b2e786a3b8fd404d7e61cd5e4182ad2c19740eb3455578000039df0a
+18 1 195 \\x0c294f297559680e73e5945cef01a6206c74613de77b802c2a792f413c7198fc315277d17fb0a6eb568ca04c733a7d01556c4b4b3d8bfdc88e3df85a810a6707
+19 1 41 \\x1ade82b3faa959a5e34c820c4c7a5455c31454e520b3eb753225eecb99340a60f77d85c5229ebfaabc438da2b50381a8875c221c84f78d44f8626ac80078e106
+20 1 235 \\xd2bb1d4946c003b7f33f30502ed81659ac5f99477da91e0d86c4a0fb475d344fb03aaacbf198d7ddaad0b3bf6672ba640b20792fe372d6b6275445972b8e510b
+21 1 419 \\x5c8abe0250d7f4316c6fbffbde1e4165b5b1e05cd9eba0f872969caf29f788e44a371cbc01deb1471b3f76c9f158ff98835d00670609fb0a8f86f502d4b1be05
+22 1 240 \\xac46e258bb6a104afc8c8fc19f6be5b9bd5d73a7ac90fa8ff9ddb9fd86d1c469d3081e9bd003c9ae44b02f2848645ed73cdc3248262ea6a10d1739fb0db40800
+23 1 395 \\x1f0041524e4c7c5a721c757c88438f05cb924d3eabf5e3a040a9dd99f4128a19891565e7d37bdd7efbc0a05d08b7397fd7fc1bb18cbc045f465ae839d3bb060c
+24 1 98 \\x739a786b40b535301eff6ec3fc2b4abe6c6ee13716fec256b39595e25760a0a8b20b93d4670efc6eb168b626e5df1c6777f0b1d5caff8e20a2d639d154506001
+25 1 340 \\x5cd78229d21ff8ebd8cccb1d13ee02d127555920f865d91ef289338492c8ba3fd8066148c84cea632e612986371e6cc35a1f7fe53e3d731d64537c3707487304
+26 1 270 \\xa103fa757c69a1ee20d6d4766e8f0a81710737e4550845ee84008300940445d82e162600a3585774cc36932a1a438a79bdfa2b27816412b4704229e28ddd460a
+27 1 129 \\xa706ab23872d2a3f09a279071af0c07a652e3132d4db06133f0634e0173d2466fc32a682d7ec931a3d706c0b6c6851ba90fc875098c4b7f11ad6c3f0b1c85e05
+28 1 139 \\x031948742c78dcf41b0c2fb64394aff794e6f30f404eae914a0b27df95c761b330d6b614866b5a19a67fa0e2abc1dfe087d9b8cd2eb281a6d51abd4be9289c00
+29 1 390 \\xfcb21a5da1dc1e53416b24d4f009556b6b3f6582a76b502b4a4e71f432ae1959d403a34781691c41e7296e5c42ac5fb40d9736cf9a38c97b5657cea3e28f5001
+30 1 140 \\x1c2c66a02b49e6c51b39b397a302cdbaa16e999346ed000c1b18ec687ac6fcf700f526e820bdf64fe51b51fe3771e9dbb214499664d9d520b5c9f118cecc6a0d
+31 1 19 \\xb3043958170efcf3af2f849b7c81db8bc0429e041d8be644ffeda4d17f01b1a93b5a18a87a6b7c15e1388eac19de357fcfc9238a1d34465228d19ed4485b810d
+32 1 157 \\xca60b054a3f9c531493d4b076a2a89f01f7bc2b437c67741ca073c65b84cf0b0803fa16c2c4acaeac699626239b0d73074499cb355cec58c8507c972409ece04
+33 1 54 \\xb6667ccb86919d21bd96a58601f725b2aa16e53d8badf4e82117e29458e5d56d01161813665356fc8ce0289dea35ff3d68cd845689c0bc5592e80e23ffb5530c
+34 1 198 \\x5be3995f33533656460ee6f8e5055f4f5c1aff78735601682bf703470949780676fc114ef640bb46e9d3c10d71c25d8299418e43194de44b73dcf936c2704a06
+35 1 52 \\x55fea0391d0279ae0f87042054656d1debec601330c2a414f50e68572fe012e31086a0d54c83776dcbb17c47ef828d316ca993279676985ab53c133784e4780e
+36 1 278 \\x1e7a966fa019e5cc116194e0c018d09850e0e8fcfb59de7bf88ad3ce7a7481c47cc1b3ff04e0c6a5b05c470d649dc4c1b1872966d561e01378080695eb0bdc09
+37 1 299 \\x9ca4a69429be91bd19dcbc0a786b7152b35babbb7558c36bec3a5c9b9d1067d7cea0b4df494716e6d1d31e7dbc57991ab7e392c401c835a639fa7881dea1c306
+38 1 150 \\xfad6eaa9e06538496a15b92ede51616aeccd700ca0cffbc201ecbc9da98c96a64057a05e14913a7725d0ff9a12b83e72525b9b703f89f5a95a873eed6913a007
+39 1 231 \\x336372e1afb326accee1153fd28a7f5173f63d09fae9dcc8eb34e30020830a081e51b6d070a2cf99af4865948ec4c0e8fddbfb1156cbd306a4c7757379f0900a
+40 1 349 \\x85086347219f6402377d82df4ed672d57f7c2e1a2e6e0dec26c1807728795814ccdddff12897ad86c2a0f7156370b11e7413e99a4c1d163075bea8ecb2255902
+41 1 298 \\xc09a6ca6c633ba63ee855aa2041cee5551ac358b0f617d505a448970dafa5007f812468c431d4e430f23e6e220207dda8a0233df9fd63af30fe5940ae44b630c
+42 1 160 \\x2faafe1b53f6d53d008369403100566af0e08fd6af0e53bba5699c600ec8a0961c5bb3894269e6f7010466210d68f5669b1cca82b6a79ee9229e438e3e4f3207
+43 1 327 \\x8b7ddfba2a5722599fb83325c914b5a9f6c50e3e1edc07894d141956105de311af6eddcea0ef9b3ad16003b73df2e0554a05c391f7e7249507b6ef3c95243f02
+44 1 264 \\x7ba2027a291cf55337ea8629ff7fb7389425fb342839811b1f1c3dbc2bea8abab88813099ab9e1e3aa50d41dac2f9e3dc00b4c53dd489fb3ce99f0ec3ee8bc0e
+45 1 331 \\xda8fcab64665fbabe49f71701585a4efeb8b4624a8dfc90f5ae6b718aa691bddce3cce514e5b8eb25f7dde831b629233dacfdd729592755101f78a9eac97c202
+46 1 164 \\xe741c1e0b424ceea9d8b372616ac7f406804d45c978a7717ac806d24a2074510fcaea4ce07cc301508c13a5cf6076bb3bee7f3c035af69e9813b4327f4986f03
+47 1 97 \\x3bc084ad32ab9d856a3f78ca704a7f8cb203615139b2fd7b942f1303ffebc3f8400b8b5ffd4ab9321524168d411f34627799f0372bbe623b706f22587b2fd005
+48 1 115 \\xbdd269a80429559e2e13bfa6f25a00c4365a9f5df00185c34cc1f3655f3c50ae23ed04e0044590fcc9ea4b5b29ac5aa9c963fa8ac2409231439fc3f53b2e5e0b
+49 1 197 \\x1fef5b3a3a9a9075d97143674efa156b40e5a03c5b51a50ba62522a6accda2285b9872464c758b0783dad7fabf448a97b0da3ada834f8a5ffd9d4ec1d0a5a308
+50 1 268 \\x7d0c3053c15b4dadd9667f6cffb4d3955f2133d42c04f2726f2f3ffcccf695ba00b2461c6294527bace3f0bce6611f53bd3d5ad71ecfc2c801bd4c3709070e0c
+51 1 151 \\x33cacca0311ad773f3bac91c90d87f2cd4223871386607bba6c21cea6f8b15632dadd80a36d8482633dc4d9fe91971a418d8d9d0ed857952300c1d57718f780c
+52 1 102 \\x587d1e9e376b806fc136e05438a70eeb653a89849c941b1c576346dac49d7030b82de087e4f5a3b91aefcd35145f17d98861ef1703a865fa24f26258ede5cf0a
+53 1 203 \\x45abf364d1b6948ef922b20972de9cced3bc2f31a3296b7b5d112ce1233adb3f1b672aaaff26a149994d800d03c0b458afe96ad5c55b41fa38d5e3a18df55701
+54 1 232 \\x1cbbf812a250ec093715aa492efe3acb18718d315c1d784f0e33a0ac4fc5fb7680e31ca2633bb666c184dece355983947178e183290d3dabda360a35d038b604
+55 1 329 \\xb09b39d317f4e4eaea9757d3d1eddfed230b88475db259bd482908924452ba0b0e27d5ed6f854ec9d44ab3e9a2c745d7d5ae340567842ab6231a2536dd0be504
+56 1 173 \\xd877e0abda526820c6f07df6082e4dfe44a2e8ef9094cf69d776e0aa21bd7a48c2eab5037f8a19732b1c0a90becdda96a2b45c4e8b0f8f6b2f585ec71054d50b
+57 1 134 \\xede1ad426861d61cd21f0dafef6e59ee2ebb021d16e6a2a1312ffbd163dd97569b438bf980ef45ef0757fbac3a388a826009dcb80a963a8dc021bc57ee030a03
+58 1 123 \\xdb17ea5e47ba915a8acf0ce235e8f1e1e35e1e02cba13e2ac2a113662a557430f06675f7e17e1c64d1a86566c66e08f412981a2db397cbf9e34eb224acc69609
+59 1 103 \\x3092c063bedeecf60e6d57b2bcc3d9e44fc2c39bfeff789855f0d710e553a315019aa4fb35221ee56b3b96d26ae0ccfe11865fe87eeed1c6fad1952c67acd006
+60 1 86 \\x987746a701f9068b2219d94e90206d0c878b25a84314f59a0104d3ba31bbdd88e3fa2e3d1f0accdbf4caf6f2c07f145481554a59d41d4d3de15762ab007e3304
+61 1 184 \\xb00fbd56e33eb2dea1812bdb441a2afea8e48c92f4bee0e5e0a6d3db7b247066535bd0d1a2696b4ab6d06d2cd66d5a3095b18a34a2806ad9f54565262092b909
+62 1 47 \\xac33cbe4c07dd0bdcd9b73c4b1771a5b878f823be9d657e1713f60c35a2325bf2489ff571cf7cae1065fda86734336124d70a6893e1bd2d14c7a87ac5dd16309
+63 1 209 \\xd586bc920c8116aea2138d3f9031f2b046402f3caf8c630daa8e87318db3bf2aee66240eb724ba3241aebdfca1a02e86d30761cce3e26839da080336ef6d1500
+64 1 206 \\x15b65c9d8aa6e50d9ecf64da412ef6ce3e5ea6394c2c8b7ee3c4893a580ddf1b4ec7640da3aac2fc266386a599ca1351a068e0288fb8951dd57ff5d0a216ce0a
+65 1 204 \\x00b6e85d285a1c8284aa6da37f6a3977da56c75b85d4ea5bfc8966e352006835d69a2911d1de857b6072bcef5368810c4ea52bd9f4fcd6c0c3d23913fa0b9a06
+66 1 258 \\x4c8119485f104f1bf020beae5085d49b74e9347b7cc1eeedc0dfb6d7ca9ed7128d217af915a8d460b984eee5d8292e3dea2a07611eb7f1a54cba7a4ab70fe30c
+67 1 302 \\x2ed8cbeb549ac005e1e0affa21dae53cc52c936b44447645151d61a216f5da6529f2534441fcd4ee79affa4c260f07cb2eb9949df04d4da984a21330b4e4a806
+68 1 130 \\xae5bc1f0226aca5136e504506ea796a875e1679742364403dfcbc984b0d22a535c562bd29c9abc8f123f1d3660fa2f5205e2fadca0c41e2dce48dbcdc4219909
+69 1 159 \\x2dd74854fdbadc82e720e488240418127395d01946f5e2f5fc2f7a565366ff0fcc2c474590ec0703fd57f8d61b5946c2c64bb4f7795861d0387bdc05a4872f07
+70 1 175 \\x403318148a4a45facc9cefc5e39ab82c66976780889868e7c61409e76bfa11571dd3640ee66b6364b546557a29e515ef183dee7bcfb9805da9e43f616bea1504
+71 1 131 \\xf44e445aba8fa818df3d8460103e7b7e6469786cd473c19f93c087aa955688025ee8d041fad0918642c8883ec261ebd229985e804b110fa5c31a5f2c7fec4d0d
+72 1 205 \\xc9412a74c4d671377a0f2da9fc950d35c6cb1694fafae83ac1dcd058bbd7c64fae0d2ad781585e01e376a019a8b19d41946cd2f3a42da93c3506a93e27730901
+73 1 40 \\x293a8081c9c1e63388f010bb55e4612f33265cb7d2b76af292852bcd1fd384fb2567d8fbee5fddfafe45b1c0195475a39763de11e8e31b1a9bda10ddf1d21607
+74 1 363 \\x304b2f94366aad4e9815fc40227b585be5683366a18bf4afdec5c42dea324908fd0ac637079834932440cb8c572ed8eb2318e2847361cab2a3b2b57b81095a02
+75 1 70 \\xcc8ef960f32335adb4d3127852b4d60dea91a06a8cc64427c498bf5b81e480f5a4294aba5a38c09211a6834004f3d0116db5f29e6f23c0b9a545b94dbc6eb40d
+76 1 413 \\x10111b9918697f5fbd199da212ae9f3183d8245fc2a9a5d909a363ffa8e5afdf104ed743f89e1eaa1bed4005266db18f865417ba82e6c02e8abfbaaf6b2f400c
+77 1 177 \\xd298b4966c5bd112c2ba7cf128bc8e01e97ca907b7d1f0324e5af784d103b6a3ce8fbc6c29f9c818994e563251519681015f470b429c34502603d29da8d0a202
+78 1 5 \\xb4882b3db6b542add726e9abe9b13a20c270fa42e96b87bd29941d4559707676373ed57ac505c689c7700144773d0222977cfa414abfb9e531d9beca2c08630c
+79 1 16 \\x4bc6146ae728f53b22bb2f9071a671919a23b1923615222bce3b944070d09e97e43f360d79fa04303c21e3ca9bb6d660e021b5bc5eb67c77a812268edf87930d
+80 1 122 \\x6cd26f81c089287d54248ef92a6be9997752487a2e317d070435edf964454faa642bd9dc060133300dc8dcdb0997a667ccf775262191077385e1e80f8246f101
+81 1 17 \\xc97f1de820927b6108b2c21cbe04a46f2730dc6aeb5d840afb9a140cabd0ccd660dcfdf422d0289410452270a61cee9e4c25e8e155223c1b8f3f993127c9a002
+82 1 57 \\x1147af51ba348e2bbdc2f5635d09e0fcc7dd6c402245c70ee1530a90b52b1ca2a9a2cece96718dde2fec998c618ed6cf63447923bc18a6d471ac8155a4c87f02
+83 1 269 \\xd19876269e5c1d82e6c4c3ef684c772e1d6dfb27c76e6dddb9f1fda36efb9a9780d2db1915e36c21ad5dc60ed03ff81ab3d56e11c183d736daf0e56fa068b300
+84 1 166 \\x76499abcb322073da74822a06f41e43f0cfc2b39c4519b019daa65fde1b22645b99e6f31e0ba0cfb8d16c7b015d75c4b6b3d594d5761281858bdf93faf25f905
+85 1 236 \\xcdf02e9ed7ffb1e1b09595a8b79761cc076c1ea9838b85e09b570de1cfdd38c9d16ee8bc222b39d7f96ac8530b64ad822c63a559c303d512a527a0b744c61308
+86 1 279 \\x84499554cfdee3e2fcaaafd1407ba8b4c3ca5a9945dbfef07b072f8a6ace4e3575f09fe930fe5a3094c57ca18ceab3fcfdc0ef051dacf535e85b7b90c2d3c90b
+87 1 176 \\x475c672cad74734d2d824858db4c58f06a6c10b815d9e6ee86d0c091c5a6120ef89b03b0351ca96dc1a911408341fc352073c04847300b648640f628bb784a02
+88 1 371 \\x9609a3dd04f23c19e3bc3cd5ad9c2800117c545b201522cd7a6007f42ed888e3791b7d713e72f619d7b2b7ffd9e9a342d1114f5d2c6971171a1466158c13da0d
+89 1 249 \\x81a585b38b7c4c6ed1ff38f7bb204812e8d3985539d86f3e40b87ee54ca66ec13295a021cb32d4e42d28e9423c2d4e551874606f3ed93c3476dabe719fd2c401
+90 1 25 \\xfc49f6afc06ddbda59c97cf721e9e0aed4eb00a3457d8447b229a04a81063fe0f3e6cf2d151bc07d0392f7f62cf933c07a8a089b201aa3ea9a73c420ba992a02
+91 1 152 \\xa4ef236692d4b4d49940e9da1c78973294393b25b0572de95b0e016b52fc9339a2cf316b5c1eb7e69cce1696099c8eb16d42b1c86d317478d74d2051fbec6206
+92 1 368 \\xbb8754ac5491accd8038f8f81806f691279805ee3b7c8df129dbe348505bbeb3b27630971761c6c23b3cc0c223dfc7f74d05ad42d1f621dc891110d01bdffc02
+93 1 161 \\x59d52e8817ea100de37df9325074cdce50eb0ac4bde3a95a7d0dbb33d7092f2d9bcb107103de987bfe4ce6a1d7c6938223e1763a257365fc5fc5e5aef49fd206
+94 1 37 \\x292af2ed2a16ff32e160c0d5392c545f41e9ecc939e95da46a5cc63a70ee6331a0d811a2e64ae82ba9305aacc2f9a03d7bb16e0dcef2516d01c4cb2a63e3f509
+95 1 310 \\x8e3622e1742997ba86a82f865a09f427a96cdae0f5b1ddddc0039e2c71f50930479d0e895f9cde79f5fa2741f9f8eef7c95b594b29f38ec4cf2dbd0bdeeb1202
+96 1 342 \\xe7c8beb326dc83bafae9cb168e847a86ea2f5ed8fbf86c98c404a644e1c58c946755dc083b25e248259ed6af8df97ec0168fcff019318fe54a6ae00e6848cb0c
+97 1 295 \\x3774c318f2f7e7e29ea6cd511a2e659c6491e6bf3f3a2ffd0df57fd435cef74c08fcfabf3ef093c41ee3eeb79669f17527978502e79cde9ac5e8dff3d902ff0f
+98 1 420 \\xec315f89a0e4fda63f27067ffaa68c2f9076c985607f21772ebd98b1257332e4222e47c393fa2cc26c920d577dea52e734677b2465de846552382af2a794ad00
+99 1 24 \\x193137517f0e75ed6e9ef22b0e505ad629f4769ba364e9a0c389f3087a092e366228b0de535629a46e9bf3e1f6762c0c111bbea1314f5b9433dea6f4b1fcb509
+100 1 38 \\x66e5b84191457a6bb5cffe177926c07d81d08db34f61444fb9d37b5519deb3d0c3efa1869cf754f49b02bdb76ab24d2daf7cdb8d5b57d5cc04cd704f5fc7ac0e
+101 1 399 \\x92f556b5bb3fa83e7221d5e576de9215f5535b325fd9d6f39186e89393664da920f798a43a36661318fc831956eb06de2a042560dc2137902143f04c07c08f0a
+102 1 114 \\xd3c8f2042cba21ec89fbb63eedb0d2484bc9816237f1cb38fae120e0f2634e01ed5c76b7dd79c63ac8fd72fb55717f60e8e6f0e84d70d0257f185ff0f49dd60a
+103 1 155 \\x013eff58fb4bc6e9ccb167bade34e7d016906f3a6634fe9204002c917e3dc810d61ede4452d222234b21e9bcb7ac486dca6463dc86b2aa4129d87dfba80a4d06
+104 1 116 \\xb4777c146648cf8a77579f83fd8fed7a3b3f2c26dcf6b7c48fc62b13c71258b3d2ebc5f25b2e7221cf2d8403bb4067b4d6ad96d6080d7573fd9ba5cc1bc3e209
+105 1 190 \\xfcd097cc749539b498640853586d8b8f88b68e2cfd1e23ad2db492d5cef2d7f0f94e2e74c45c38ca45d5f73b544062ff6f17c614d7e4ba9b2508752c01868503
+106 1 365 \\xae537096a182174a0f705d441005b85a8121a0fc28eb6ca1a32534fa11b3fd88f44c822ba2e2d8294ae2935ede3bf7f5667be2427f46a0f687d8390aae7caf07
+107 1 148 \\x4cf2aaa26355a96ea367ae11d52a2d35ebcc2ef5e915dad2cdffabf0ba155c0c13599e12fb5b73d78df7d6bb01af9195ba12ad8d1772b8bdf00b60dabadc3d08
+108 1 61 \\xa89152522c7c80838e97dc3d6290d7dbed9263f2db734dd2a3cd1d5fca0e012e63c43b406452660b509e89801c5667390d749a04fe9f0df9eb72f8b65899770b
+109 1 171 \\x8a7dfb68a0a36e22880b0445cfb2398c77753809f3f393f5e80b98f7b610edb6c5553956785013e8fc0e786f5ae1a8923948c2bb6865bbbfdff8d84767ccab06
+110 1 144 \\x8e9172c021efbfc8b530e415540f0ab03ea35f0dbdc1fb0fcf8472ea26a47c1644e09c3def1874ae96236e4aca7401cbaa636c0bf40e760991016156befcf70c
+111 1 280 \\x23733d5f27909d06583e468a611eb1640681f2df42405e1801a6380299ebb3df943a9b464c412188c6856c2bd611fc139b81a9d9d2b6cef1797056e53148fd06
+112 1 220 \\x40dffefcbb2acc17741b8cb52590e2622eb7915ed233852126605053c814f47184bc21572634bdbe46a2e51ee31dc9538a86f32c430d92aaef635026e87dbf09
+113 1 172 \\x3deef9610e8d74edc2d8c71e70a8080a3f90dbcd9d70cda332085fe781723e4e781aaa04c1a7832f36c4733761df1f3e1a77f2a5e7209c65587d2b7c7d6c620d
+114 1 360 \\x35a1aee149fd937f43dbd82b0fa55c85c3c95f8b9b1b02b62d40d6a0fc0c20fdb5e8696a06d522d90349e55b0b262bc360f8cef35530bf1a566a3795a103de0b
+115 1 398 \\x6fcb9cf5787f53615c8a14387ade9dc81e794a1b9b08de6c01b1a4a81f372c40e3ea1a6ed19a3aa0942cbadd23fa1377af1bb5efcd5118e92fb295cc1ea27b0c
+116 1 228 \\x3f3a4b20760ec9139cf6755dc92038dd5e3a4b3f165033b826e90524a7280a458110c104865a61fd6a0bae1998e5a94b1ffa273d9b0151ba6e8f23a87169b50e
+117 1 90 \\xdab7e865494234f15ab5c736f76099ab435666e4eb9aa27f42b4043e23d69f5b1b3adaa051d43aaba356ec83fad1e909850f6634a8fd04d4bcf67fd5c8c40a06
+118 1 253 \\x0a4e42f1c5094a5c1d6e47d28da5d461b1295fc565a6286f5af0e8fc6afc70240e5b92c5456ee39c8bd459ed8a878c3a724ebd2fcaa45207f6598027df01e308
+119 1 179 \\xf8faabbcb8732d1b05c8c96bbf9048e0585552e2716862dca25ee9807517067c8a90181a45351d06ec8d6a66121230cfa14096c8177c09703cf1e5241d7c8800
+120 1 45 \\x4a563b876a6f365371502de3b9f22ceb0ae2a793a8964982f606f1a80a0d8b4d7ef65929ce51726e9a61753f838c4a7cda32d2f4035e498aa7b581526665a008
+121 1 277 \\x4d327fd42dbc4c62d3f35032005053a7f8149513a2aae2452ca272fa2abd74979536e3b92c5605339068c63ea8bc079f7933a622307ca46cbe0be185ea1f860d
+122 1 284 \\xb90cb53a770cf18825d2e9116001f722c189b9bce2da12c08c2f8ffb3259dc6b604170a7c51a6100892803fbaf90be31b03692f6ce15db481fbd788455494b06
+123 1 234 \\x6af7e44b08db815296903f32f3c4c93877e494cc5ca9521370efbe634e0619c0dec1f747a90c504370442682dbfb3bf2d1a6f6a2bbf6172c18bf148fe8197e0d
+124 1 53 \\x7b6326f17f11bd18f5e5b9ea6a747e747b4c4b8772e07f65e4c7563e71033dbc272f729a2358b7fc6acdbc53615b75eb7d97dc48f28a74fa95bbc5d838631d02
+125 1 95 \\x8ea7452ad6557e1506aa167f861e9be0f81676966f71707679a31b370c0b392a03f1550d7ccb0e46229c07180f78543a91734f486134f91d6d3851aa16055f05
+126 1 281 \\x63c5d2c002ca6ff05e81ed96276343871fcf8c430800bd8c6a7be22daf1c4d9adab9b43d595b3cfe954538c3a0a1af0d80a13fb359f1e590e16048ff6c78aa08
+127 1 353 \\xfa6779bc51942bd488233b214af8fa0e9c3a58c5d00f230a60c0c69d7ff4c99bac7beb616d3601c42339389095ba868d5a8d0b806ba5a6051b17c7f6e0af0607
+128 1 217 \\xc6d373974154bc15a4da491c2f217f42dd8e784a66b95dd660a3317241fbd31d768bca607b51a19e81cbff22002c5e609b1aac918e1284bb865a335c776ed006
+129 1 156 \\x7f96da32d0f3d7511f96ba188beeccc648f4551ae1e623fe3b6f31db86b269b78b48c682c98c7c0d325f2b60be7017102b1ab7abd737610e2b7ca87ebcd55201
+130 1 250 \\x5b35b714683623e2a0c6ce15e573957384274e0f3be20e7abee31307da80ca33fb1589e5574f36ff07ee510bc46276528bc19d220b4044c1582f34ffad015a0f
+131 1 380 \\xe4c704a48005624dde50d05a6ecbe7ba8bd8b0e9865b3c25d7bcee83311b95939e1973cef23381639ab312b3da912b7d10701e42e8b77c0593bf65f477cae800
+132 1 136 \\x07ec39c322baeab5d455d422f4056f91d4b9288fbf86c011c89fea49f93cee568e623e74faba27ddacd8b50c3f5973f33664b94a4100c7b7fab27cd95af82008
+133 1 337 \\x58d4c27864c3252fc6d097f909a8d2ba438ae2773454580af43667287fb8e282c2ec5099e12110f15d567c5b5d70f2ed185eb0a774fc71e91a3edce2017ae907
+134 1 294 \\x360bab3efe612912891e351982662feeb4a2d5f371284158eb9f1d5b259db92fe37d90c5094e960bbdf17ea56a335d354a62633863320f5b5409c4ce22eb7305
+135 1 286 \\xe8b82736ee20581c8ce2c032319767294c97ec3d48fa2916848870a3525bd61906cebfa0e2d806bb647931530f642331e11a32ee23691ffe0565a52af8e8a201
+136 1 296 \\x6d1d3a04131d10d4caad5a4d7c6c530778f97561722a3a0d14224d42479ab190d86e9747a018ed4195938714726c6c7d33e79f04be3304123a8b214cd7ee6f03
+137 1 251 \\x73b415eb0bd462d1d27a855fee5049f7f517f482b8f7711b0fa0ddad34eee4b0bd02638e7439cf193a9390d7a2e1dc6d4b9b694934d293603f6a9cf591f78304
+138 1 149 \\x872fc95a5b9d6d4e33b356960590bbec48997908e40c402ea3164d7ecba7a6c1010a4e27735c537ccdcba7c28b625a9124f8d07214c45d9b8c076f4b33cec10e
+139 1 196 \\x3062df479d576fb14276dda35b2d736f8087b10be7642a4015b90db0ec87147f3069b61138b37252856a105e02b8e7c315ac3300fb59f2f6502106b9b67bbf0a
+140 1 29 \\xc48d45e2510af07e864f23d17cf34e3c1f15dddcbe20f14a18ea8b998002552c3813e12195e61efade81bf98ea30a37633b05660ba7a4302293ba1025d675a01
+141 1 154 \\x6fade8f89114ef17f26c37b26a111f42c1ac5802db4b008f42805ef180377c81673895c8103a64fae21a62b468bd37995ab8ee646e7cc0f3a9d429ab8e7f1904
+142 1 355 \\xff092e359b782c6d930c3e7bad08254863acde3f710b322b43ee12042ffb6da600874515debe3c9bce8af31acbb7c91134d6dcd9a1f0de833fb8fb623465e50e
+143 1 185 \\x8cf5ef75ce9b21212e9eb12c4f065309a354ec8bc40d83933e7a384e13d01f13896a042eec1b501819dc425e773d424a6ab61ff24e8d5237caa115f5f846a900
+144 1 101 \\x06d6daa85c23fc58021d6372980f269d9d8549c8b6a39c8393edb59044e21555622129629a221c4287124e070be0dd2f61d3726f3319a7c8dd146415a4743503
+145 1 213 \\xef8c48a52e4802969fc90526b911a49c1b7651f88302ec5e4f1bd0b00cd027739991373f9ae526862cfb7894977027f6019eeda126add6f403cda1379d78d506
+146 1 247 \\x88ba83b4e9893f293015c2199c17d60cc8a8be93ab103725e47a609929b9561b3f9d4e6035233922128efa55e24eb3501a10e2b83e37ebc1f67c4fc9c57e7e00
+147 1 293 \\x2e864dcb5060d4cb98a03e13a0906ce7b65bd3b30af09a020a74a28dc69130107f9eebd339fc671212726692ae34587e114ef5ec16910c7cb5026c2e115efb0f
+148 1 135 \\x1f645d910348ccd3f717eb06470f242202e9f8f333dd33e307dbbfc551ef97bf0bf0ee3a51e61b0cdc87d864bb3fc86f5e01903b17f95b49a24cf0ff05dd0901
+149 1 357 \\x5e6f69313268efee9d5ed9c137beac170867aece7370111105f97541dee2108ecd09616002a4d3bad9ae9b7609b97b29782fa1c9b5b6afd60eec511bfeb67208
+150 1 22 \\xe6d3ba57845787efd0be7f2d1f7354a0e8681c3c9b88911cec79400c44ca87f8c22c2848e64452e21350be24c333eae12a5847a15d67a723e00ca29e41fa2002
+151 1 239 \\x3a10759ca3a627b00446249b049afb85ff072f964162f14c8ac21eadde78b4c4d16af94591627176d52eab124db041fd40c3f14a5832f6afb428245387a8d003
+152 1 262 \\x0cd3595bf0918eb5456022cd82df62c677c0d3a447e43651ebf5b85bb753ec1d22ebf2d482ee7646ca1cf87e345ac5c05fab6249f8ab897fed85cecf07f5160a
+153 1 285 \\xa4e96516e5e20967d49fb8ce8f0cd013262fa38556097a31bafcd1d868d974c40913c423475ce21616edfb932c10c3fa1d7c503e72f8778b8398facf72103507
+154 1 263 \\x60a1a443c673d983d1724b5d2433a8ee3a356523d902fbdae0b01e356917577ec74cf9476dab8ba7be67e6de06ae66b2d540ed4efdc4ab07958f9bb81bebbe0a
+155 1 352 \\xd363d63cc9f47971a3167c6de5f72d93a2fe7d7214c8970019db641b850fa9994e4edc3582a7fa76cc5774a0be82369bbb5f704980849857ac5a141733431903
+156 1 80 \\x1c5f1b612af7b2b8be6b75a36a7f1acb908b6357694c43c9bc00ead8597e21a3132e51647f43da608596f59421b27ea013df234b249c93ae146ba15249b5000d
+157 1 393 \\x2b58f41410c5160341656abb80b9220a3d0ddfcf28d3e4973f68544175820895cade5a72c0a79a6d7b81d4518a76d0b65bb5b3a82d4f65b21c903a269ad2f701
+158 1 305 \\xc360b77015ac3c382f74cc61a7261fa15495fd9f569a0f29140f2262926725ad5762086ca160e9d6f4b7d5c1022c7b84deb419d5facb542200bb8c90e4c1d004
+159 1 167 \\x6b093f220a6966f8668e369b8b3b6f669263a8ba5e2f8aee82f2487fb6ef4f80c94e06bbe6ab4cdebbafab386ecfb5df934a10e54782ad2c5397575e472e580c
+160 1 339 \\x4d9156c1edf353a5d3d9e89d499c389f8e11846e2f5bfce3b3dce82993f2886fcc2e6dea21e1bbb5ca6b0c083f69c3571b67b76539e72367e358e629f88d780f
+161 1 362 \\x3a2dc3f2f1a1ede2e22685c78a4a4ed8b0538431f9d0ce95673ea2444025da16354e8b779b69eae71b9b6fd5bd6b2f22322b034d2db47177d70fc4916ad71a09
+162 1 138 \\xd68d6525b678d68f4509c1d1257619841b7d7dbe58240c63286728f6e0e10372b1e70812c38f9ae70de6c6c0010a1f68a0784cbbc185711cc6cf076b5062fb06
+163 1 76 \\x500f0075af712dfaff7c88534b1c49d39f75e59ee9d9e1448f3ee3a88cdf9e3a5a2610d6b99df3596a93b919dbb8dc3a0d1da89bc8f2930d19ad4d3941fcd604
+164 1 163 \\x15f5e8d2f0db9f16c09366a3aaec6d8bf905981b392830f7919427443db3e746846164bb667b9bbdfd3fa5a414f299589e356346147da5cbd693000ceccd110f
+165 1 66 \\xe35f91a1fd109aa6b7e9be5bccfec423841b938c9d15484f18b060ba2f373a8d72612c9e86e46be6511ea4e80827697416baf874b1c0412675f6a6176fe0930d
+166 1 314 \\x4f20343ce851459ab380ac2f0b78d17bc94ecd016472b35e6caa8fd3706bbceef063dea190eebb6592c873e8cef98f56bea6a5c8d2c1d506d2f298e687d8ef0c
+167 1 400 \\x538010e3902226d16349b4c5393619c8c502aaab140f80e20e7dcac75e294eff46e2c24407f491354e5241b1165f79f856c66e3230cfe5af08f57d53118a170d
+168 1 13 \\xa5121e894063c83aca11b9b6cf8f2c5a52483a7d5ddb62447693d7530afb299c22acffed80ef23a192275ba7bf7c18567dd6191d26c309b53dc1975bdbd0950b
+169 1 128 \\x038ea07c154db88cfe4222c14b148b5326f5192caff640c2d9d1bc1b4a8ad44e46bfe755d0653b275b3333dbb50cff756f88b3a3f3d1542b4db4c54957e4470c
+170 1 229 \\x111171a650c77d6cdb1ab6ffae5ce13accb73d85336eddb6b8221617fe889e54fdbcfa3789c482580cf7f518a2e839a515d9fb6b832f178147fbc48ac6213c08
+171 1 72 \\x3d4ee0ac827cfb805c35b02db1a94091107fba7f1d2afd9f5d9dfd44ff580c182bf4a78c4d3cfd3ad0dc6e382f71afe8bcd202fb652f90a697c8e38d94c24e02
+172 1 104 \\xd827ae75316ef2e44dadea30ea51d52a1f709bcf4d5f7c6c906549c7a811b46e91f2880dd71f11c0960324440ade3e1877e9c530d05785e5b985b26815b5b803
+173 1 311 \\x0e3e19af02ec8651e68a65d6b2ed06e896ab3f7a57ef127d6361d5a99e2622c468268d0c2556cd801f95b984259b93fdcaf3b4fcf48c97829224b5b5e5c6ad0b
+174 1 230 \\xf046bc7ca6a2f735e1b0651b69d2ebefab06850d1a3fa24fb33c8bcc0bf9ac7f376f87df8f02a5918ec511100e04d4ec12ce64e273fb9f82a4b2652bcbe1ea07
+175 1 174 \\xe4f48737dde0a9dc5595c154fe3b7c1e38f2122684bb6dabd7fcf4ff08b36cacd8acdb0e7843e52411eb39abe0148c4d80899a67dfedd629e4eb52eace342308
+176 1 132 \\x82716417755023a0fb8658e19d78a745a5279382e8d3d5d7c73b8a67b49be3e8a5bac1e9ae6bec896c66f4c13945fe22f47a8727646895a3d515852d81534706
+177 1 199 \\x19928b9ee6e205a5e5ecb81a7170d3c062718c8ee6f441eb07e967f104c1dd275e0ce728c7cf79d1fa6afd0445e87bd31afb8e884e4e9be5f6c1e9fc3a7bbd0d
+178 1 402 \\x194ed6da8ec1232c48c65a493829c07fe1d8997db469cdda0ece0678bd37219c96e062cc0048b97374282398524a30ab4592437ac95e312addaa74daa9d52f0a
+179 1 62 \\x196a87859cb79a1d3c93729d3666a77c0aff7420e268ff28092b4ab79d85c45c16b3b4a68cec1ae6b87940967f97eebdf28d2cc4d28ccd038e698e2a70d0da04
+180 1 266 \\xe6ead3c5f35217d776ef6c17926a474ee95a1fa4c0b494bf327518ed1f2fd0a7cde3f8be89da8344b3710be3d563329f64227ed1dc53833c730b4882029bab06
+181 1 93 \\xcc99eb886487180163b811f1016e8e820ef1a6f3c6e1a22f05677aab21ac786da87f64d8629e4e9eba6f75a856c121a8fcf83ff74db70f39e7ed4ec407cf940d
+182 1 288 \\x04d1d9e22a068ad667cf118167506e83229f9828f4c4ad8bffcbec01b181bad9d9d58c7f14ae90655e63294ccad6c129d86151ff802658ab61c384acfb506100
+183 1 109 \\x7dd9ba9293df0e18c89bea8e5b88a8b87a8c06eafb85ff93c30b3c794a974fb044c98e2bb14124a690e5b0b22f31dbbe728eb7970ecf93606269fda53340660b
+184 1 28 \\x0f0b4dc8b5878d0f8d342e5d9ebdc462d4763c02fc8605d6f69f129dfd16293978fd82defee559cd166852c4b2d0f8c3be553f6c90b311241a03d1a310890a0f
+185 1 51 \\x1d20748b3d88504714bce11531403f289fd9aaa55c1ebbbc2e7640a63e954b6c81d4e05d8d373998039f740188de5b4e73f1f1b6f1886498ee1fcb8582294c06
+186 1 421 \\xd265c19f0125100a1ea93f3040e47f09036f8f49162200eaf41995544c7b30a03c17dd03022dc7cbded0d566321b5dd0ae7db3c793f24dedd7a1adc1f29ae202
+187 1 30 \\xbbae106a733d5f596f5a997cfc028337ea7a9cc4e237f6cc19d62b915f861aebb41e3c527aabadbf6e2b3fbb3ab446cff1129f05674cb28b034b4d7649a01909
+188 1 112 \\x6a6667f21dc0bb131de5dfcfe0b7a7d06d6eea98c7a2e79f7a9a29df3ce306ed8449c57c14111254049922bcbb38edf91cb0894bbe6fcd9f7892e6007c37c002
+189 1 64 \\xbfa8411e5f6671633644336c3e1d079af4a617aa10c8d91f7ee82dd78e07946468b4b96fc234f08949899951e066441aad284e4e572c67309a267181a711a705
+190 1 275 \\xe05afa31cb2d0b297cf031fc609744b60dd9a38034223b1147aec6bd698cc3461f35d8ba2405ebddd70de5c96bd30db124ba603804ae718d0bddf621d1293c08
+191 1 265 \\xa27f79578c5f117b5785da42116ed16438cad4d652d022027d1f1f3251fc54b2de8d0f0edf781f753a526a9c2aa3d21fd3774d5cbab4ff3183d5739c8e88080d
+192 1 351 \\xb7565a1328562b06e6b1b772cbfdfd51986afd81ec6e7a1e76c3b78d7c39a42b1c2bd6d2e750d3f8b26320ddf8b9afecb80ab8e41da76dbdbb779cf62322080e
+193 1 238 \\x6a42d1815a339b159e127374e06f43034509d50578ba2b651c4ab240e52a4f6d0526fa4f23757fbdb11f5d04b2e82ce8d8d6fbf3d81dcdda1c529652b32e770f
+194 1 267 \\x46760d1271698615171e5ed1b998f3dda87ef417c916481671bc853b984252f846e27657bfedf25f8e23d1115a83ad58e7cc59617680109d9f86ce1fcb1ef805
+195 1 343 \\x39a8ea25644e06aa3b746e2b48b97c402cef66ed167468c3103444e7d1b9b757d42b954525a1e2b31366d16c5d402ac43eb852e285c89966b52ff1111db2960e
+196 1 69 \\xdecfd74ff01caead593a3ef6b59232374937bbc18095d3515210b796e6b2adee967f66a46bb3ee66a8e8f8f7ec20428939ffd563d37dd5edd3764774d56a3406
+197 1 272 \\x2bcc40e2bcecbaffc92fd5271eb72023879c2c0f92b0c891d41c3bf3baaf5d22bd4f58311087a4d22f256f99a3a7ce920e8bca4f4c1b2f82a7f3189021bd330d
+198 1 282 \\x305f0d0b072b475276cb6aea4bcb748835f0f7d270bcd6660f6ca9ffebe323852999e470a228216f7db743b7d661a043fc5b59cc032c0428c998c9739f5d860f
+199 1 407 \\x02a195b3740522b6d0b27a5f3ebe617b9174954d8e0a18f03aeee52592988fbd0762bd81aac0aef5ef6b22b00f50b9d3f7f0318bd1e9928c7676c329c8775600
+200 1 333 \\x0415f706523ce3e6f058d19b13cff560734a5b52cad7c2a94a4db6abcc359d23ef3afa516652f7987828147d950dbec0bc27e1e5c952f15abf09d3dc23606503
+201 1 317 \\xfbc81f222620e438027b65c29c0257578e0c4c277b66ba44cfb56bbde61d3f7d2c02ab2b323f1a26286ab40045a428b5885236e5b507c6bab14917b740e42a0e
+202 1 369 \\xc4e433de8a507ecdb862e8bdaa5964da20396c5717fbe05223bcd380495f17d3bcadb5de526b6e7f4e9b4f7e66e06cdf43dc42733b860715d454cf2d6d97e208
+203 1 414 \\x4a98b723517f11522249d1caa820ce8e4d7829c4c603af9ee13126176f44edc699e34fb680eec2f7b14a3c7fb2ae86e21a7088dc55a8bc69786aa493139d7906
+204 1 320 \\x6ab1985ce7f91efaac57b962aee162378abeeac9902368990ed1a41afb3f5025e0da250aed3613c0553d56e936ff66eed02234d19d04c859f569a03c94f7f10b
+205 1 186 \\x540b7857933a581a6450fc10b4154977b1a744443f5cd5d401ef99b676fc49f7870b2ddff15e8b104fbed216fa1265828767702cf12426f6f1c866d7191c2a06
+206 1 392 \\x9582cabce9e09679e052d410fd5e028f6297c2671ced0d72f5516fdb825cd2264f4935deefe6b8ba244bafde6fbea4119cab0540888fdc042c85f60b559fed03
+207 1 233 \\x9f56bbf75fd4ddace9c7cb6527120dffb70d77d54e134425e89cb0e21b7d1a8cfbea860a3ecb400df391b2c99245b9fecffc7d4b4cddc36d360fc89e50985301
+208 1 46 \\x17ac2bb08eaebad053121222c0885eca57f02f8b583ebf31c094689ea26817318b65380d6e88570a952c0f175fd51f6efd208ad8e652ceeec32e14948cf9af0e
+209 1 273 \\x0d68e858249337c4e13681e5e5abb99e321d0632748e86f9f2884afd6203ed2c7360aec3004cc10d883218fb5d2aa5b90a4636782263166912140e4cf9219a07
+210 1 356 \\xcdb90561a4cb91ad0ce3f91e04efcf1c073636619c76c8e22903dc2fb4696b3e57a0123b8e580223cf97ebd75b2949b2e50914f36a68d2a67b34f92f982c3e01
+211 1 336 \\x277ca37e58ca26956f94ca80441d826a419827f514976d0ffee440b8bfd88cb0f4788f2c7b03f72c7d68cae87b87e57ec086eaf1a6844b5cb5b81a321fce5008
+212 1 367 \\xb0bd843ea9182c60de74145b9b011db771e23f0312c14beb290c3e5368c76cb1b1d088c6cccb1579854b5ded94a7f634dc08baabbddbb659c5400891e428ac00
+213 1 124 \\xfbdf55774c6ea870b30b38176bd41a8a16c01978ca3060b26027078c2010a4fcf713599cb7f3495e83da14af725fdda5c92afc50df39f240e2882a64394c6e00
+214 1 212 \\x5480e7e72040a3ac911b0727d1d0b275b77e2923bf0c1a74256684df89e29b15f10478229701cc6679ed029f31c81ef9b9bc9fa23f45a7efe287340d18464401
+215 1 377 \\x30ca73f53cd53c42794b4ca51d5dd2953caa0b3005d0a044be7aed4d48a37f2e2d2bfac61d2fc0b737013e03c7fba77c884cbc77e9895ecbd8bebc4b11040c07
+216 1 326 \\xef05dc88cda8a9e5e3681eb21f1182ffc7112a93cc8b84a718fb86761aff88c17807b2b8958a16b87a1e44e9fa1b3bd7e88af7cae0bb4c308258adf2fb719a0c
+217 1 65 \\xbbf54f64742a5e2074bcd743b81d9e2f9aee518bae0e65756e3b7ec3d293a09191a6f2d958a0adacec4214543ddb074ed3a99e338d7e18abce1d43e85a402508
+218 1 192 \\x12072462a676eb0d2a4ec34023a3d9309278bfded23491e50376cd88ccfc66b7cc9a856c04a8bce236b6b442d642e9bc423c01f6cad51255e504382b188fd108
+219 1 100 \\xd529fabe53cf14da649561527124c15b9f4eac63c2d71e9389f70ccc709d72b6d83ad06d8de2641540442cc92bb5c6bf3dbb95b7752ceafe9dbb25837c83c607
+220 1 12 \\x5a9d7329dfbfb2d9f590eebadfdcc46ff4b1c3a18fc59738aab9ea80c3e88d600622ed887510a79b2f7b6cca74e90076b6eb24160e7b3d3527ea7df485096d08
+221 1 259 \\xd8ad5687b2e13edfb0eac7ecbed46924b6e40486a49d8f615c502eba8d4aadbd5719b7c07082ea84660f8619613a0997b0ad400c67fe14a0b79c3a57fe3e860c
+222 1 287 \\x4483fb23eb6450aa09fe08dfe4204615ec59f27ab77264f04f5cdf340c8c4a25f242fe782e231f1ef8283cd75485f6f4678003b12465e94d70ffb44a944bc30f
+223 1 158 \\x9d5904ac5ce218107735c68bec261b88aa071a553c72a639c0ca0b89c681a39718c78a00aac20b1bf906a77a40936fd5c43a2dce5cd2ec36459752b82af3b102
+224 1 375 \\x1c93185d539456b62df2ef8b08d9e0fb23aab1b16e880f2d86206a3ae29b1d2ae053663eced5fa75a67cce673bf5a04f81fbc4291ec3b6f5fea4cf30ee14410c
+225 1 322 \\xf9eb26f3f492a7f3ea5b7efa5fd7de97842cd3a54d003c991a544ab0f81e795d12b489b08320b6ddf36e4642f1f4ba16df0f5469a220214de85a0c79ba0e8101
+226 1 243 \\x0ee22485312510a08220a4a11688dbc1e7f30660fa7b65300bdc9fd4e6d10ee87b8e49661b3e2eeb21d67f7f400f8ae0c846f9abae6ccb18740d08add5ad2902
+227 1 246 \\xf515592f34b6b31a431829c2ce77768de64a6b9d1c448cf994941f7224ef9ac0d0167190651ce13b80299c1250e354d3e5b89949c7325298fa9ed9ed3cca3302
+228 1 378 \\x2800f73eb34fc98717afa993deb1797cc2a44f7c0c1e3031d6dcab9f8268241ebf6a4df3059d7cc52dbf3745bb27235ec31062576275918794ba4c983fdeee0f
+229 1 381 \\x89bea7fa7899712cf882b12e091ecbd759a3da8dbec16c90eea7420b31b56b9d9424a69dbf25708300c82d5b7eb7fb1b10107375f0b94a69b2e5aa96d605bf04
+230 1 145 \\x71c3d3c4724f372a5c782165c73b1ec2064183a1e6232dfee67da3dfa84059ff30b8028d820f6d54f22848f4e498cac4520ab0d004cc2e361a6ea393ec98490d
+231 1 71 \\x26be5832ce2b2d118f00bee4546a4cc296c79af3aee34e4379115a3894b21b1ce40c1117b453ef6dc9be4f7c344b93e5baa76989da8dcc9f3b5a7127dd699308
+232 1 388 \\xbfa3cd9ebc86aa3db2b28b8b3f160d479a7b4763d5adb4285a3d597407a4fc804a80a483d506f03e9cdf51ad946019e27c3a0bcb18be25f31fe6ff6cdd71e005
+233 1 111 \\x3effc64b68bf4b0e3fe827871a965701fba26d22374db045956d580e9fd17f4e1c522bcca995fda7d19998c05247090fe81296c5080bf628cac3591547cf6809
+234 1 344 \\xaed6fc94af52866612209eef2ef35628bb6f9a89669558eb991ea04f99c03dbc4e254a3770220f3fcb29a8f89185313a2a783218a3413c53f0fb38cf6f170c04
+235 1 147 \\x08ca8c4c396f5e90c8fdfee06ef95f8271bb55cc2be51dcd6ec688eab740ee94d6b3ca1c525ddf2188545143fbde8bf94edbb5aad4aa67d3c60bf5078b9a3c0d
+236 1 168 \\xae971ec0107d5b015b06d018bae4dba6dbcd91759ff2a8f4cd5907e2fe417ed59e4eeaee13b73a9270722e9796baeabbba05e566e2bbb331ef03f3045d59ed03
+237 1 226 \\xb93d65e43ab2a730fdbb006d43b50fc63f109dbfb726d8962d30411f64d1317b0dfa0042cbb71ba244673ad790ff07a7a00c09e5fed876376c854c32f5083d0f
+238 1 193 \\xc5e8caac48e53e2a73519c639b9c68b9c806c822f1d4aaa0b6915ed5b2eeb501a270b847a0a2178d12a0c00db8a3365db80683d18ca5347141afc654d29a6d01
+239 1 376 \\x0467dc373769eb82983b89dc855991c60aec389da6b38c247bf64bdaf254e54e2d4ff969412b727629f16558090878ccef651bb7467d818f02009fd3b257c600
+240 1 404 \\x73a66e5b3caa8358ac1d9cfbe2785e18a537a8e7439c4b4b4022098aaf3dc9cb21af62e33c670c500b8aa276b91b16d1041856f46d62d0a0ce17b7139855bb05
+241 1 18 \\xc41d09ca5f7195f09f42ef5b0e8b0634679d011799c54df5bd642729e3f2af8a4b0a3dd15d767bd1f5eb4403c150c95ae4d3701f420b850f2cee77ad9469790b
+242 1 91 \\xc695717d15dd8f2186d403a42790a8204330cf997f414164d91a554456b60bb09aacdbf165e13543838ad5d5a1e6948440ced96b0aad97156838044d53a6df0d
+243 1 94 \\xca36a35ada97b119b7877a07eff74dae7ad94eb89e9574d86ade8eb837994f0c4e5fe096c1be19da1746c4e81f498bc11f8ad3013318793c1553b737620e5f00
+244 1 401 \\x285b1c292d9318638384aaefbe925312abcce398fa9beef3faae5014f3bcf4f43221a3af69f82347bcfdc55d67f00c475535728aac092653f6c22490de9e480b
+245 1 92 \\x7cfe306099952361878233f0773935b288c15f9a03893828be28cb8f2f93f2dd33fa15223b68482b3fea6fcf40f49a97d5e9c51e63a5f71f9d7f780e55fe1c0c
+246 1 108 \\x5d6cb52b38908cc1666b3b79dc49af655cd1946f42965b16c3e60354ba6c934d24752e803610c5df078840f9164e2a8273ef1591d7fa97bd6ce408a5da4fc808
+247 1 394 \\xeae0b4c686e005678aa00e37890de8a7d52d40013aa84b444afbbdec77850fedcb9ba33534275c51e59fa028087e2dcfdb9960319425396593d26a3a395cca0d
+248 1 143 \\xa9483963cccc1c5eb902164d56d51878822aa3754730cf472f552ed7a9bb9d7ad98b928c6a3be0f9143fc37d86a9d7a5b3f85c0602ca0f4a02fdb0440824840d
+249 1 55 \\xd87941f3feae46246503b20a4e85b37bb8af5b493e4863cd13848d4f64ee7d8ff1835cf89d4406e8d5ffca497067c67eb027aad6b201606b93cca8fad9628508
+250 1 207 \\x528489ae0eadb2c1054bf51a8dd07d907c098f62cc3b2ee9d28be329595c3b4234997a8ca0d1fdd6d359b855aab215459b739da43a5a419b376926be4c2e2009
+251 1 391 \\x01004df8322a1ae41fd40ca317488c024a9fd491ce5798cb19b9ad7f015ca266483dc9f4155e94ee245d76573eb7adc2244ea3f144111f5467378017831b150f
+252 1 361 \\x6a55fbe7e5616495728942077f256002eec52cc524a4d58df290f2d9f2d40a9ab0c96c91f54d383bd424cf5856733a3edc14f0de302856d490a73c6a98634304
+253 1 312 \\xcbe7cf73e129e7c2fcfa1c33ab4c83f0d6c5f2836be5e842150603aeee902cd10a32a32a6697f77395c7832b54d35da35b067669caea77c0e0eadf979ee62907
+254 1 274 \\x10b99e849f40e3e31c5dd2cdb1795e2819ad754a0a6bc6c531624b154a9f48c3b1267064681249ad910c93fff82da7798cae736422bfeadfde516561b88e3a04
+255 1 416 \\x876b30279032160b29a460eed20b8d45c5a0b649b4f55dbddd1ebdf020e5d87483471fe33d7a8573af138dd3591334c80215555f4944d5be44ad05c3799cff0f
+256 1 384 \\x84bde94e2f074394a886b0f57f4a64e014d80fb68bc8da90379f3f83691b1efaa86837ca2bfcd57d2bdacdc6c1b20dbac3a071057e59e0acc6a8bd8893781007
+257 1 9 \\x0e881cb20fc81b6e549271a8787136bcd0504a3fa571a3af6eff938b15756ee7afca71be2468657c238aa96df0c015e8ec9b93a10e32977f5627fd9cda042000
+258 1 301 \\x099a1ed6e215b095fe4ec8ba72f4257ae61c02b7b0ad709239e44ab5f40cb9077be5010c7893f33568c333f954d3569b92d7caf0f101e0d9395348947f1f3408
+259 1 283 \\xbcce9c1b158e8baa7fd1b769350eb2623426ff6b89e0cd4f2886448dab24e6a3450ffae01a68d4a1d8177ffcc8be294afc6aeac6cc4b2306b61cb4e6d982520a
+260 1 118 \\x6a35eb2e993c6a6d43e5a1cb587f231fbc794012a119366177643b2d1ac5d22853e892b8f75d9f47c6c25de2b182f465b1b99193bdfa52b00ea7e0bb038d100c
+261 1 338 \\x0abda3341094efecef5b9ece8f1a4ee2c0d0c6a577fe940f0a1058127ee286115e11d83784f5575bafa38fb8f42f319ccaca06251387a4cb3999ca713b774a07
+262 1 242 \\xe146db68808771e852860c1730c09007486205139059d88ac7ac55c64ea8634c936a5cd70ab4500fbe54f62489a64e8b9b5893ef829661a0e763fb25de72e707
+263 1 256 \\xa05ce7163c05efe42f584cf99c5f371977d58215f2debf91610fb3a0191b5fbfe3314b885e2ab8cdd67bd4fa130f6daede302564b452a916746a60571aac020e
+264 1 39 \\xe2b1d9b6d2e06a24d086330092fe16006bf5389ce5e19cf72d358b4f7fca20e2a49eb54c8a554180e13e8b1cb4027eec35dbc22ce34ed3d77272a848d7434a0b
+265 1 383 \\x727419377145042dadb7f9db6fcdb31c5661b83f8bc09c310c77be12f568f0a390c63315efcf7bc401f2218c1a0c51d14c4ed49daba2eb8f23722559a95f8c02
+266 1 1 \\x3f5c18205f308f7b00b877d6e0920ad4fb0f78ca5fff12274e49bce4b7e5124690168282d68843cc28cc1a004f8e3d37b43743be9e57eba4d6a4129cd484de06
+267 1 50 \\x792211e5a1107cc7ddfbe7b521155d5cb32867de699d4539201aa7b15e4e83443d190d0eacaa3f01eb621af1fae990db386ac689f7937826cd8918c98e637009
+268 1 347 \\x8229a3fa1c1ef9dc4c6fd7ccd5e9c135a5ec5b88302e48c72be279b1354a98a852f9db1e339c025eeb2631a9ab2c91115b5ef83436516d8ddb2df2989b0a020e
+269 1 73 \\xcd3a13718f390d62e697dcd63d40a58da75062689092ac7105ab564537889350fbe4e31ce6cb92641021cb2f0d7f1d0cce85fe3985ff32041eb7a3d53b5ebe0f
+270 1 189 \\xcae82c11e720c5183b436232c006871a8c119e48a92bf34f135770fdef5531dc704fa3e01fe0bf6a4c5acbfa373c058bd743d8fac0be97d71d01e787f369dd0e
+271 1 418 \\xd792afd515b9a4fd058b747ea325f30d80eba6236c6415e4fc6d880020ed6204b6961a0414ced015ffa8dfa4705b566f36476d0cad2cc0fa5e2227b09027d101
+272 1 60 \\xd3ae051c19969d41a959db3d5b54b2eee098bce0baef0c6a0521bf6cfe053907b39b29375e267e8475a1cc615de82199ce2041fd27ae362fbed2e90188f93a05
+273 1 241 \\xd4b67b07a9aa6adf8d420bf0f58bd125ac6423b96e59d754e48912be3f17c64760c3d11c6e70a9ba89b073aa8db331dcfc4d0244bb471cec45974c59a1825f01
+274 1 303 \\x7dc57ddc06c7cf73e9dab639458e0acec0805d1b83f91bd7919fedf491161a4c47b65e5b20c96bc1854c2fa5ad1a37d68cd471c88b32d69a19095574ce096f0b
+275 1 127 \\x097155ef693033eac864fe33d68a6bb5cdcf02ac606e8b81dafd8e2467ca3a92166d4e8de7beceb03d2d77aaaaec9a1f9eb1604d08cc5acf680999a707edfa0d
+276 1 165 \\xd152f5c0a3d0d28e3df561b9866848dd506245ed70b462021ef4a2b915d7f2da21b03894b235680721521f547966b5a58997faba35a89974989fc1697dc1fd00
+277 1 254 \\xe74a88a60c5a639b862956a485c5aa203872627138f34e95bf4aa7ed0ca489191290775809e853120cfe20928e4bbb39c0b50b22808a498031d6685fca0d3708
+278 1 188 \\x756efa53c2ac07781c487690a2c35da425b845e44dabde253e5df281b966dedcb6aed9be79169153cf5a0c5d3861bfa1b8b972e320bb110e2def2b1b5c94bd00
+279 1 36 \\x34f0bfa73be6e7af4b82fab52136fd1eb98aa883f1e53ac10e7262f35671a0c6eb1abf667fc1852a1f6eae9c5d11a099a278638ceb6b334a6f14d21a55f74d05
+280 1 325 \\x3d793e9119f4cba85e2d6a5a64ef304105c702ac46d15d9de9b981fbf8ae17a588fe4a213f5b2870f2b4dc7dfc41d8e81b6920bb02eb1d7cf40814de26852105
+281 1 2 \\x8839fa5b128c17023fa3feaa60d60fea0196b97c7c8e50fca4d132dcfe7104026d58a24d538ffaae867942c0e3689caa6d9253b09ee6a8ff738874f30c3b8f0e
+282 1 141 \\xee0c7999133df00e766ee17cfa7d125c90dfc442bbe7db8ad497b5b38cd0644ab14492bf71cf4509f124af5e5e902a90c560117bd4520a301876beb67444b501
+283 1 237 \\x3d0cd128eaac6daf4f67c82caf96f3676d534e6b0aa1db2b6e373809fade86aa565cb58afd5d2602cbcbab62f9e4327bc50c4d6b05f54ed36631ffbbf52c7600
+284 1 315 \\x62e7d3d10cbd51713a2c3724b5ef8b2effd96f36c4bbf5485734b11630bfd77e4343da94006fba785125891cfdd0471ad17c696dc58f6f478e998a76bf29f909
+285 1 345 \\xb20df19ba45be73d6b63f32521449d1f3959f8981ab6c4662b0e9a39c8d8be075030e436bf9d099d6d63f504fb8bbfa921bc5beb8f7105874f9ee26bb60aaa08
+286 1 330 \\x25be0a1b2db06bad3bf2f019e04e6331d38f8a399a81a708e70d80390ea3e45cee516810164c04cba1718c100735f05384ed8dbd617cb4812a2626abe67f2107
+287 1 85 \\xdd8bae45cb1ef8a34b1c12a1ed12c8fdbf1b0b2edfad5e0a1b89119f699caa631208958823126db733de7160e3078ab30e2c24a33194537c6a0f7c6a239d450d
+288 1 373 \\x0adedb9ca7e36b453d6a109885e9999e21a3bacdb9655bfd47453590c4209a5fe7f8f5b36f89a90646a4dc7802847b543834fd7a1517444bac99e685468a6d04
+289 1 142 \\xf0c2427ef75927401cd3425a21a332a7b42ed68c6ef6ed7cf3f4a71dc2f7fbbca29a96d066662b66464442a2b811a101363b2c9f38a78149b2e24bbed63f0d06
+290 1 162 \\xdc9fb850a137da530cd74751cf2868bbedaed64fcc4f6973c64335096cb0b7635d28282d9784a317b3cb840ed748b7d9b16f4b83d94402169694a8c71243d40a
+291 1 297 \\x853eae3816562a7593467c01851cd1279f18448deae112843df2826702212fe129f2421bd1ba1ba797d90ebc07d75b3c8c11f0a61f80fb01903e54e9dc7b9300
+292 1 321 \\x1bcd3724a8eac9f395f692c0488b68b39da988182be312a26bd09851e6b99685606cfbfd4ceae0de22fa6b2fdd349cad107b603e7ceec13ef8fca19990b91905
+293 1 105 \\x7778434b982546ecc7345458112f914120dde39d0efcbe06778835dcd1ece86542c7bd54a5ac7ccf5782b47b8692369e2418a46d380996e39e63b34c63a2ae0a
+294 1 257 \\xb70a74a947c1722f47a6d5b65b9dfa1a06063c188ea6fa45ecd5773300a6ee015958c035b379539cfeba179299cc770cf3307bcb5591b43730c6a4797991a607
+295 1 27 \\x78cf4da07339c3badbc32575f433b0fad71f55e1c1063e706b152c4a724bde541f7b4abeb6c177d252f6fdedaebbbca12896a9637cf9b1479797d45a041f2d07
+296 1 214 \\xec548853a172d389230c1042b3975368f5a434bc2700ec6b7613d13450b61b1e0d6e5845098632cd76ca6052b47d125981cb2ae6861f16ba141ae89b4bc8070d
+297 1 350 \\x760053901d290075aaa23f90c73d14b40319da51f6cb02d3196112915c23e6183b5833bd5959067d2a245777e5d3ecd3c07e96b1b5e595db74284213febb8d0a
+298 1 372 \\xf5e489fd301581e2149f4154c584925f12051a14bcebce596c4bb9814f7116c04fb61e8ef83ba54013965970460f66e0081943244f4f6963c59b25d299f67d0c
+299 1 75 \\x9b0698edc0e9d6a967a609db25ff4e0fd0642ffa2f969cf3ce149e6e123c5e6d2e81e100016cee54deaff6e3a768b36f995cb484fd6f969b4bf1af159192ff0b
+300 1 201 \\x8d8cc027de9d6b90865045ba09a0cec5777b81f897a0381263201b8dbdab65872dffd0522a1310cd9db494ba2795ce936f5b780f99869d30b1b3853ed8fee10f
+301 1 68 \\x0b5ed1077c09c8fbd5d682955edbe250d68b3e2f1852d0c712881732737919670165239852306c4a2c0701d0fc9865c4242816ecb9dd72c52c688f5d1269ed08
+302 1 354 \\xc3fca7a38a0997a32c0aabb7b1483e431f72a07c9783a08799577c1469fe13d448ceeec0ebfe56c1f3ed513c4079f696c6ed2bf2208e0e30c64c866aebea4b0c
+303 1 26 \\x90279d6bfb649c0401603d4bc743dfa768207760a81301eae6f72050d9298633b74f8fbb16e2708765e50c9e121d6e731a9887a3ab0a72e10153b2e0dfb4bb06
+304 1 335 \\xfbcb785cbad3f00408ed11410be4c12f73690e00eb54ad3181228c8be415cd67eda90722d6c0a939a89dd7fb8e7a95d0e8b08af5d1725f2aa22211f343454504
+305 1 290 \\xa91074b8bf0cf0cc9bc9316904b867d0c887da4572eb8a0684160901e840b909b3da2c420e7aec8977943a74872e4843a14e56ac9cc0cc187c3631117aa4f505
+306 1 410 \\x8bf6b9b8ddf476657f037f647e423b1850b388af550fa0e42539449e145c39264356cc8965f7fdee9bda929bcdadcbcea162d4248fe83f8ff6ad106cd7d6480e
+307 1 313 \\x798bbac7d6975d14b1891fd2b96782192ebefcbdc08f6a698d90e18a7aed54cedd00434972fd50fb85dbeaec2809f23b2dd7bf1473d20143fa19e9124341680e
+308 1 389 \\x45df91ad75ae1b13c34c592150dde5d336803144ada5a8046b25fa691f10a801b79b18aa48ad7b2c449b5b4e82293d7bb913268ac765926e2341e5cdd329f209
+309 1 323 \\x43e002e8d19b0a86421d86c2b8bd4d234bb2895a8f5bdeeed8b517b40179ba97c2ef24670e53a53be33098ced5fc0b46f79342b62520c54bd472cb6ed8f37e0f
+310 1 44 \\xd06d205bbe11a8bcea027f18677b707524e0d16c8138f02cf0b6712525dd56218c38d78508e10a1c5c34dbada42957f76d3a4b487d43b216e6ddceabfc98db0b
+311 1 210 \\x52d860e24496938c6c032f3efd582b70ea779eb905f6a77e82662095ee78ed8a06cbbdeb2455b1a284212795a9489642502754c297849c3b53f6c799d4caaa0d
+312 1 153 \\xa0c138245bfa88c34334bee4d972d1ffc10bb6b5d9c668a348b6b696eb0d13677ffa1f080c4b186fe10bdb2aa38d4c582ce88c3c76c5851aa2a83719a5e4c80b
+313 1 133 \\x6b8f8ecee21339e5ad25247a1ef9947a71934a38c0d226e69c483cc43b5d7fc5f11f9fea39a086749b1484e85c1f2fcefbbde2b57312c405fce01eb154628f07
+314 1 106 \\x14c554841cd0c36d9e3e2c62f35d2924e588293a70757ec560751f7b83c64eea684f13f4e54dfb1d82a306f81c1aa72df175eff8527cc9e892580d3b0c4c890d
+315 1 261 \\x84d9137cbb0a38d76a3b20ca9673596b6f17239924dacbe0987514c64fb2b21d0f0fa7b61fd5ff07f9a6a67c30361bbfbb7932b923bf3bf91f71905833458609
+316 1 34 \\x08eeb0b6cb89b9dfac4b305451890307372e18f7b706fcd7ac5136729092945286dda886cfc45f3e0d86b52c71d06e228aeb8f44752c37b9805fe49160c89d08
+317 1 328 \\x49277e12b0c968c05c17cf717cb005cbdf9d1c50bf198ae5598805b96a9a8b1e793a799af93a03cb4c3d294d39cee9dd8b9e9869e134b62d81bb877d334fb304
+318 1 211 \\xbfb681817f9e2014db5b23ca61fb69aa634b0f65fc734618c359eb464ebabdb6907e2d71e651e199e8641b782a9e099cd5e25604e0f5679e6585360d3ab6b001
+319 1 77 \\xfe43e99a1d83098e740fb99d4a0105fff155c00ee68546a2ff78c0230433c60671c95f416f37e133eaf59a71b004206dc69682d5c7907798d57320b041a3c80d
+320 1 412 \\x9a36b752bad7f39ddc855282080ba61a9c1a92a9026c22af39484ec5c3d477fc6916c49a92f7cab14e2bbe63714830ad7d85cb957bd97046278eec4be9c97901
+321 1 307 \\xae34b47703ce3ca807830b82725128612a5b090b288d75e1aa6ccad6886783b30bac261301682006f8a99e59d9d579fc35dbf62b53b911c7a302b5ed1113fc00
+322 1 187 \\xf00f49fed6fda79da30be4bcf4698ef1634c5bf088ee05bd8f5ce167d04042bc716c1fa6fd5bb39de132a7aa9e71359a7682f4f6a9baddd7fa6a2ad4b2a13000
+323 1 422 \\xf30036ff32b0d9dd163d3500362175951801bbcd62832d54332ee9382fbf9a59112839c009d21d017e4f343d82ed80046109c61cecd99496a994e437d0803a07
+324 1 255 \\x5ce60615f78ae4b9e4a294d216e3c56339a837498466b3f49e018fcba04760e1864970442fbce15a95d13741d5f6231e710160e5742ea65edeea86284d6c190f
+325 1 417 \\x792892ba802f2684dc9009703956d3508af0ad8f5b70cf80a96764b2b00a9c3ffdf2d4c31b586655639551923caa39454e6942847d1ce5a95516657debd9e403
+326 1 8 \\xe14a58e2b507dc2b2f7d49476898da22ed8d3d22fc393e90274269dab3ce6052a38e55eb9019c24fa6510d56ab5c22e7e663476d32744136269399fce7292105
+327 1 370 \\x75211a612811d0fc3ac7ce88745e0c6fc2f2652ccd1e8996cfda8de716b6fc654c640d0ab267f70c001278acf214a01992aed7f59e3349bb8434fc7da840a109
+328 1 63 \\xea91966b20925393be3766b2ce70d34bef6353b3cc08ae54c9a9df1d4d5ac8a9456aaa970f73bf7f32cfde86e66bffeda5bba78bae63712b0f75974b8e569200
+329 1 194 \\xa3fc13c79bf2cfb2028456666fbc7d2e41030ee4b266d24ab9bb7ba4e7a56d25045695c0dd98c8855d53100c0ff9a64e0a3b5c55ccab56d351242415b8530107
+330 1 6 \\x84ed6299ee4827f749c5cf0705619bd8a634ad3dddc181389ca57a6f3b8850a0ffd3ad5ea6deacb9d9f01c90ffd2be237e81b9a3449e107d69a4fa9b04034e04
+331 1 125 \\xbc1bf4c23e94214cb6cf9e25246a79b4aa0076758fcd1c87625f52dc4e6999800be3187d1d245513f0934411c83e9b193bf325db3e8a5a1fd4aa8bea84553806
+332 1 87 \\x75db2b0ad46e01ea81d963ad63dba6152b1a93a8579d5477720a3b083931e4a02ca61d65ce3c4b82019a12e0003a71cb6413dc0b0f86e205a0518bec899ec108
+333 1 379 \\x4b8d3d2c50d1a561a10a3593d522287ca0e72e16f90e61e64205d731c7fb7845fbd24547a9bdf87cf3133a1807186f2aad7271ea833e035dbab2eec4da74140c
+334 1 308 \\x8f70e49859fd8a516f4b388e621eda12384cd494a77108aff447aad08aa213359febd2d309ac648a2ac41876e1f6d23a818b195a1179a781d1901ec5d40a6001
+335 1 424 \\x54a056307d28b998a0ed3340f5092027c001c31a79117b8613ff89e3656a55c9d084012558b10f596b973d81879a87c2c4c93b90a1b96d65736ed4f6de323202
+336 1 382 \\xcba8ac160f695fedd8736fded816de642abccff4f5427f78f5111a04e1db631f6efddca4a85819ff4b6ea0bfa853a44921cb6c3a568051f971556bb36d9c440d
+337 1 117 \\xbb70d4c97499794ecc251b4fd59159e0f0357c02d2169ecfbf4facff9b998ce98c7ba3b0e658938cf13d82b0c292576361dfa4360ab4601dcaa1448c728db50f
+338 1 181 \\xb8934b96c3442c9b9c64a2bb04fbd285bdfb86f28b88562b5beb685bc55450064328d35111b4cb3606c8e61c7e419e3bcfeadf178c793295c9b94960dceaae09
+339 1 319 \\x44f9f9c68e893d4934436d6372e18a3a7b3672edc9ad93db1f340423bf8892493697ece71e5c2881cc2babf6a4ba7366553668310b44742129cf6aba3c9b320e
+340 1 227 \\xecee394ab88e496287f6b293fde9eed964a7251f5324043b91af6ff7a152e0c971bccc60b3deba3c06f9993541e01ded2fe06b027b347543daaf538253f66800
+341 1 218 \\xae0bcbf1b126a760465bf112ce7bd73274366a7da7b64d3e0d7bc8587989b5f8ed6ecabac15f0a8460fae9b09173d811249f81c37c96ffe99dbb39bcc470e103
+342 1 334 \\xa9ff39bc95e6eeef6153060441101ea113bdd87fdd1a54f5f9cb2f195243743e42f25edf7f6d89c308f40b281659e7549f692916e95016d2f5f30fedd5afb604
+343 1 408 \\x99493bdaa59d918abe36b20052bcbd14875a8a09a96939717f201d695648148e243984cd31127acd330fd46b4eca6ae36c2d6b676d5ea810aec77c7e73864c04
+344 1 271 \\xa14d7addf3909aa8a34f967809945000ecd7860a49d5708e4b154cf39305e1e8bbf583f326827078203ed7f9471b0f8a380040f2d0529fecbaef6cd45a8fb205
+345 1 35 \\x9f9f3992b48d9d835075a7d54a6289119b4ffb0c37560111eaefe19854af2f44c6e7cb6cb661332470da9caab056cc417503b674c743181afe99851f2f7f7102
+346 1 42 \\x4e12febc103afc2c2c9f380453e1630cc2d975d36099a5e19b9efee496104f6241e43ca484fc7bfe54b1b9cd951265515a7387a5b683c4fb74e594ad2e254a08
+347 1 341 \\x71c75dc50e4f865fb6374234ddc49b577892ba546193050f24fe7507e405b2a5e98f0a0d2e78def0af9054b81d25059819f3b7ecc81a8755f3d536181f5b7503
+348 1 304 \\x3cd653ea9b6575eb3e288b87715c049026c2f863a6d3015a23af14213d5ac7f80b909ba03d0525fd0516e57bf0fcf6d878df6036128e6ac6801ba595ad61cf08
+349 1 191 \\x65a31048110b8a2022500468d15ee2e3a1896ca388c6cf9feebc55eb7f4153ecda305a82e47ae0d450cfbd2620b0409ad981f0a8948e7a09964272ae94c99107
+350 1 406 \\x25d463163900982cbbefeea1f162637df406fe556f9687a6f0c1a2dad68b4756f81ee12c3f46ce0eb9f781ac0658905469ff276af9b27b4577854bb5f9239f0a
+351 1 396 \\xe43492200de7c6a1158332a38d4832bdf19796513a89523983026a1c928b34219ab9d7b2f0e9eef59f6e10b2b8608b62a474b8e34a706216434a46ee3b040e0b
+352 1 183 \\xac151a1f17e0bd37061ca2405b86dbb28636d15f28cb5abdac549f92ad5835f9a63ae68e54aa3878f1ccf56e8e4a7176f24fac84d5b9fca3358b635572b4b201
+353 1 182 \\xa3dd60939b5e5e74706c1a8035ddf2b3e6862dbb8aad794bc9203b2406bee198fb4e90699ad6a2769ea2fcc7121386e8ff391cfd6a848a546f8bc71c9e932100
+354 1 82 \\x922a445393c815d5f51daf23f970720a191baa717ebb8c10891631fd9c0c9ec95a1922b714f01055171aec9a85b14a7d08a346c4a9e6ced27d77f917fc7cc804
+355 1 221 \\xd28effdfefcdfb1290dabaa268af4258d1c419f7c56736a5870a4e2fe3e3b71aac205c1aa76558a5617b4951d6767de26e1bfa266456a54839a2c856535b5f0f
+356 1 219 \\x593011412b5b9f46d519ceff14900678989f8c1c01b3dc5d50a8cb0b1e454b6b25934423d708b7cf0f619957138c8e40417c6b03be1796a431e66ea29a97d400
+357 1 3 \\x7bf32e22d110da1d7cd2ac77798d2cfc005bd3a53c8ac8376c147f3ad5a095a1c68a30dcf5fcd57354aa0c132aab15579a935ab252efbeb3495ec6ad73fdfb07
+358 1 215 \\x39345b1c7b0542223ccde877c7874ed5feba02a5b596142c753878bf32b7800d4a232a8faa20c50a81209e3e47736af932a216014d611db2ae1de1258f560a06
+359 1 56 \\x334c5f0a37733da2488273b05747396615adec3225cb80968f577fd8961814654514408249297138e283157457429a8b417038b68b2f086d7079561a04960b04
+360 1 359 \\xa283dcb7bfac3644805961812769173ecc3d9aae7844c02f4d516016ce0395f7b5568e2744ef777baec9336dc017e28c4015c339a56394f26d8f442fa9e99e00
+361 1 252 \\x0f9adbd9aae500a0ff8ed1d4efcba6e18b325b87ef0fc9b6a57d2aebf9b47f0f09f59ba7f022cc2de20a6f1cf51a04a1299c56600e83cdd6868abbcf891acf06
+362 1 300 \\x4659cfa80a0a62e5c58fc62ff01101ff2985f45adaea036d2366556fac84fe5439b9e1124e3c83430484d075159074bac3a39b4633d7ccb3764fa16f29df2b07
+363 1 358 \\x08b391fcf24b1337dd47b372c145b041327ee40da06442ac0037a69e0d959cf0c18ce05836dcbe8d05202de8a5784d7413ad3f2c53e28ef178c87fab38a5610e
+364 1 409 \\x2e9ece322980a23f01121a3e7d031df81f57639c7cd91bc2ed1db2bb151a492279147f881adb8f82c982d1734341d1ab67aa29d91c54f02ae66c802382ae5109
+365 1 202 \\xc3f8fc853e1ff84315b2393dc491c46c686c41eb348bd81498835bacb6cd5f6c96473798a5b6cb8b26d292e3f812b23f311b320bb82bf3e449c787bc77af520f
+366 1 348 \\x9ca1829f5d24fa205daa14a73c10190655c3a5db150773cdfa06aa717bfb3d1c40b5e9eba3a08b9b4e3680440c1f1eb227479c350e65e0ab145b168ab73afb04
+367 1 180 \\x2ed20cb8380b9cd49af3bc6854b6d4410879a356b447bb0595f894fcb3f3d4c028604c7b0195077d46f9ff7dcb0b26e69dafb80f58c190c41598d0991c74db0e
+368 1 21 \\x8dc8243ee995c0af92ca4c38579e7bc9ca5eaa5525300bd029e6aa774bd6f2e62c17a534d92ffd02e03520f7c74ff57178b6e07f64157dbce10f1eaf1e505302
+369 1 222 \\x20f2365bd2136d1712aef7e726c0a080e9bc96528e88a2508ce19f08fae2ec78a33a143e6963ef3241764de77c6c184c40b2d3742b8ca59daf04030b9e9cd606
+370 1 332 \\x8ac3e2ea66b483901404c1be554661ad6f0be79766097c9a58273a15024d3618bf7336f9fdd282c835b28466e3d5f3018d6c025a5cea3827666a995147cc5208
+371 1 79 \\xd82c89f9af962e9c29b7f52ef861dfcb1413c46d970a75087b698d5663ebc3344beb0a652b2c421978d05959c2095d4dadf71b93bd904c0e2b12339409c58507
+372 1 88 \\xbd5916b9f43946f387ffc9bb4bfd8ddfbedfefe15545db6f98eeb29706ba99935a8a8c6c708593ee143c404d2679f80a04509e82fbf2d2cea0abdb5b30085609
+373 1 7 \\xdc23355ca42eb90bc74591613262f15cf58f45219c1e556379593756769bd43ad78540546f570ef94f12b6b77986f72bb378288909d5ac4caf97bc9802420904
+374 1 405 \\xbdd0fb261a434dcddcb967851079787c1f15b05893ed9f2e31c564788953492bfaa678b8fa38f247c4653f4ff6e1d195d7d2b802179621d4ee08eca8a144960a
+375 1 386 \\xc3f8b9910444cc8d6f3225d68c33db069934bed04588c9f857186418efe50352d54207eefc3edc8f20c11c8ab2378d2da8e14e7d5bf3c8da73589f1414096809
+376 1 99 \\x2048ba15a918b434ab407c7f5ba690cdccc5a550c68e4caccf650f2454e7f405a7d043a7c8c1d9f42586058ba4424f63423ba63b5aab478fcac459ff0a335c04
+377 1 59 \\x872a91865bd0ee7cdcbffe9e912901cbeebb0712c9a7cb78b8f0b8ac4dd896939413e365f9f47a2fc28d7b576f18bafb508e8511ee35713497ea1bbc28d38f07
+378 1 411 \\xf69b775d3079aaba6a2310365a0383a131747133bda395ca071922547f8efff8fd8a6491d970bd99b4653cfb3bf422e755a024abdf93e305d5afe252b3af3904
+379 1 78 \\x9714f3ed8aa3a5c0e4dce4b2f3f39919f0e1f45908eadc0a3ed582404e0473d49380ea8c59e17d12771d82c83f6c3b26d5c12b7b5dec82a7ef9eae75d6a2760b
+380 1 309 \\xe3cc41e11e71910c671d8ca4eff9ded5e522e7e6fdb76021536de1b1b25535d1cdb980fd980327bc69b2dc600199177ffdc821e62c6d3c8a381eb05798773d03
+381 1 260 \\xf18f6b12dca5f39a0e9cdaa6375f4402822c239a31d70bfb85ed265efcd209fe49c592eaf8b179e16f61b853653df1026145e7c16062083b6be75f63a76c750b
+382 1 291 \\xb2994a9bd16f25af89fa454768af6e4f5489a28a62fda75d4d8d9989a8607a88fbdeee33c87fce28464a7a59a4defae2958723d2b03178dc97182aac54399700
+383 1 107 \\xdbe7496d9dc1032d296230ad3aaa69f3e490c9cea69527edaf3c38559566c05adffb92723f1b2640e07d93ad613071f21883365aa2d30855640881f6f88b8a02
+384 1 216 \\xd36e4a5eb2dbef27027468845917be310189b07e5f6fcbc0a4e087d8a3585978dbc500662f4904cfe152ff0c162e3d08e7a70bc0b8fa0d81afd09ccbf06c4e04
+385 1 43 \\x60b55e1780ded89a366c52ca58aa54adb644faf0178663c045b52000cec083fec94ccc20ec06299b4826b82ab79001cb7b5f391ef3c12266bbb9e33540650d01
+386 1 316 \\xc20f4c4d52173cbf700c843ec3e27f64987e0cda287b566585eebb22908f4d1321d33ed9fb05f227af2293e2faeaf14a5594a247718632e4957c84a90a091c0f
+387 1 223 \\x98bb9f57155280cc46d61554c7645330a33c844a6741e35d75d9840cb0c354c8b3c044302c5c1c1c784c936853f9e638d433ba5edb2dcabf3859a603c22b0c08
+388 1 387 \\x1f9cd388884e23c2c1e030cae221c3a3819bbac50f988a57dfc96f856fe7f0b5af3f4c42660c88561ee3351190c9330c77ebb8dc77af0c5dfa77551d9cdd8209
+389 1 58 \\xd47ddb8cb0ae4903e0a2f4b2132240600f303af3830e5dafc9d678817caa045608a7ea482b69505419c89724b545ad25c582d19934de8d4c630650a67de9df09
+390 1 289 \\x5e854160ef2c19eef036de7c75acd80d75fbdf5e4ee51c58e1f315f259ae0f9b03bb392700db24a29baad41f19a89d9b115bcc359b91352dc764f1b5ccd4e008
+391 1 49 \\x659e2e78710fe26c028e3f8df6ca8ee73e2393838cf1abb7f9c4eb8737549b7806f716af74b93154635875f262e2fc959a3dfb99cdb1fcdc1f5c6289cd8a2603
+392 1 15 \\xee6fd7770a17a9f7cea153557839aed9d0cf97844570ad003e2a32112c4d893c3bd13be9fc0f5bce09450c83086305eebf58b800726b640448634d5c2839f00d
+393 1 119 \\x03c14f4e907d150a7329761da3c181ca1acf8aaa8043a97e3c6e12e590137cb29af811124353c8c2fd9cf79067f6549833c4f0f46c25111169412616b439c404
+394 1 120 \\x53258acd2c1fadbd7a40c83de108bce5ec5488fd7927146a44ff13ad007ec350f569f7d6928b17436658cdf54ebcc6a9864c77c27afd1cfa4816f44992557e06
+395 1 397 \\xc325d5e31d2c02386c398dc84929b89b6f3fcdaffa468c5c8cff48e6b42a1249baa7097e142ef010d836a2c24e158a3e5e803eb5ef57392a7723ade051810902
+396 1 20 \\x3b100474903711f1e7ecd8d46848b698f2f2fe67c6ff653e3d63314b5c2c683f7b69ad1dfbbb27aae1253f2b19bb0dee0ec97951c17c5aac0c97fee775d8de0f
+397 1 169 \\x196596a4cccba5337f9410e0b9c8409b5b4fd3dde645c7fa7fe5d89f735843d211db907de9eecdd77325d063bff0e024a76bef3bf1aaa52b11549a4b968eb10a
+398 1 83 \\x515da605baa3c569076fdaf89c9bcf1d37869b7085c7e065723d7cec997f8e5534a541a82ff3adbf451d6b2dc3c90ea1706058dd6064b236f6b0f9233a702f08
+399 1 146 \\x5398b2988ace36a540fb9b54cf8b0686e15fe21357a75a5175106664f53d7a1a34e9f602855459219820d92f82f9e26b694714004cb4e2d9ed7fd94188e3b809
+400 1 4 \\x7967a96d51b64974a1f186a8d681d7165baae4bf98de8fec329d50d514c4dc40527c1e6a8191d9c5dc466e548c50b5012fcee2380845258e27595df2b213e806
+401 1 385 \\xb054314bb68902b0ff49c1c24c116be177a6481a039ee3ba53c245f008c81d84e3136fdd9963b804f82434db2cee049c32e5d566307c64ea00968a149de4d90a
+402 1 31 \\x3f090ddd00da4f09373091382980b7cf3475df51b98054bc0af8b70ffe15f30aa4ba43a803d8d6a94591c78a781fa5912191647eda6ae8763a0743a1acdc2402
+403 1 32 \\xc26d9163f6f6df8f0b690b1e9a6f60f97cc8593ed0bd25cac343ec9d8e8a64eabb0046ec7fe27ff93920a4c9fe052676133a0385ee3dad46ae5dfd6c9a51dc04
+404 1 292 \\x950dc2b770b8f6d4b9c3dd7c4423668b2e12b87835932dd4ce4438bb71c5641fc5f549d3c77f83f0b266dc5de506a58e4a73216b6ec96f5c35685e203a417c00
+405 1 318 \\xb91e86b5b6fe1cfa64b4ced85512dcd38ea932d5f4123123d171fb5c7b4d85e5721490eda95e4e0ce007a6155278fd719c7a1ae5b69f2491faa29cb973ddd30c
+406 1 84 \\x6949cc06445d9c8338f8db58e228a71d46d04953fc28974305b5a903681c5dc087d9ed07fbd401411fb49064d7fd7cbaa809159159e9078e4d8b04cd1806c703
+407 1 113 \\xd73b11a297dff4ba8719a810abfd89ff1a7b54e0001daf8ee2a830d7df2cb3305fcb587c03deca6e4f1cfe94d051ee6343dc975295516c49fc5fab147ac93406
+408 1 137 \\x9aa181b071a5afeab66ce1a4813b87c298103cfdc8950d4b5bd174bc191bc7ab159a59a953dd0a375015bf66cafac7a2bf4c86d98b59b6b080a8f0297318cd00
+409 1 415 \\x4c5441303fa07a10ff04174eb032142255b408312a8e25cd1e32354ec448effd4a762a5f0853e7ea2e6783149a2a136b2defd087ca905ba8965523d620615401
+410 1 10 \\xb0c432f2d6e10d0e48bfd2e61fb40d586abcbef3775aab047ad8e3af6c8ad56c057187e4c5cff9106c31ef92e4bd90231a2b6a71c1122c007ce955b680349201
+411 1 366 \\x51f01e5572680c84ba223386cd8519ebb1334b85f5086c90c56b2beb5a2caac24191589c96a892334010766f6cd213d28989fa9373c50b7aeab6776be6bae60f
+412 1 14 \\x0d7941dcbfbeb0d10722512b28fd19f28af9c1de63cc2d79bbb9e8f77796e40f104fe251649b736fe0e4dad8e3b280d08c59e5abf31b3b6bda5041cf45769e03
+413 1 306 \\x1d818037a21e4e7026c7bb1e242489d2224774cd3150e980a5f216de35ec6d521fef94853bab8690a4a637a79950a620d95cdd3ab00a3d843ada76d0bb06ec08
+414 1 89 \\x8e8f82f5ce0492d7f47166fd37876c7928364749465b6917b75e2d277c71e08b7f44f63aa984f335e1c68d69b571dca8148fc77199a0298b40b755a153b19f0b
+415 1 346 \\x2aab1421bf380edca31f8d31e3080457215a4f5f50c063de24becaf3abf75cca3b52032cb23dec52f7f77e0930d04932c916f8df7a3d68cd5bcba0e55c6ffd09
+416 1 403 \\x438d9b414d72a5793fc11c9dcbf5204a3e325bc0e6a5022b78ca962204ba8a6bf72246adde142ea95489e01f73fd14492f3ee73d964c701813d750febdca2f05
+417 1 248 \\xbe2e624240207795fb63a63e31a04aad75e8df35243d03998d57eb9bcb23ac81eaa577cab71af5a1182e972b831e692e74a1b1ea62f9c376a5add9efdb5c350f
+418 1 208 \\x62adfafff2c8afe4eaf8d83cc8de0c169a1aabe6422a104064078fe46bdadeb3d0726b4b6324e93d0d36bfd8e41db548333633fe4921d14022a00675a0e32201
+419 1 423 \\x33cbea90a1cc345f4b1598e96b07dcf15049e016817d445ed1ee26142b4f7f797f8b0b8f788c827faf58c0b127b562ef8e549c3abd82616fbf09e7d24712700d
+420 1 374 \\x8571ce63dd839ed50c5a609cf04eed6b878d41a80b886f342fadc19415d60ab25166d76b85be3b6f52cf172fc8ae67ee103f4404a0cfd3abef6e4ee123e87906
+421 1 11 \\x21daf4a716ea3eb3d720a54d2d27deff95cb721b9d9816a77286be812fb0fe4edd7e56a71ad1f82cb6c0c8216b6805acc5fe3eca2444f9e1fbf5f085cf76e300
+422 1 48 \\x1bd62f3dfd1531c0b24c251554d9470f0b0d23a60836f1a59c8c10fef58c1edabc17187b6713fd578c02fa0c892d1542f922a91d8ec8098b4e05c1b2a34c6d08
+423 1 178 \\x05de6072205b2c8c099ead9b12ce0582c9a3536ab21f164d92ece1bf0d2afae20b7abc675ae93e3475b6c18c0851bd3015532882f41f18b3fde9663302f38207
+424 1 276 \\x58e6f8c747769d2737cacd9545cec884f8810614d32f81927a31735721776903517df464e042954ed60120a1a9134395866eda6bcd279537f16af8d24bff180d
\.
@@ -4898,7 +11901,7 @@ COPY public.auditor_denomination_pending (denom_pub_hash, denom_balance_val, den
--
COPY public.auditor_exchange_signkeys (master_pub, ep_start, ep_expire, ep_end, exchange_pub, master_sig) FROM stdin;
-\\xc224b524084bc7ec63376db8b4899f2ec3b0482bb6f8890560b236cdc4e167bc 1638356907000000 1645614507000000 1648033707000000 \\x70e9063063f4dc2e3532a458ab590fa6c322362e45c3d19736b28f770d79af0c \\xa96df026c9d79a0556d6ed540e8cd4465ff397bef464c3d644f401b3f3c27f4ae4c04a21463d16f75d1275404447c02778884e4370086400c3eca5e4f6d19107
+\\x9501597634378d1f2ad3171af88e2d909c99ff909d06e03fd8d8b638b34b1b6e 1655640367000000 1662897967000000 1665317167000000 \\x9bd85dc28e06af0b1bec2d0927025abed8ddd199cbcdcc41cfd996598cd4a83d \\xf94cdd1c684c1e6a736bb5c5aaec3d5c4f60310ce02f2702e35de62f9297a9d623bc474fb42bf174eba9a0938594151bd7cbc5bfc4b70987a2dcdd8cb0c29a08
\.
@@ -4907,7 +11910,7 @@ COPY public.auditor_exchange_signkeys (master_pub, ep_start, ep_expire, ep_end,
--
COPY public.auditor_exchanges (master_pub, exchange_url) FROM stdin;
-\\xc224b524084bc7ec63376db8b4899f2ec3b0482bb6f8890560b236cdc4e167bc http://localhost:8081/
+\\x9501597634378d1f2ad3171af88e2d909c99ff909d06e03fd8d8b638b34b1b6e http://localhost:8081/
\.
@@ -4947,7 +11950,7 @@ COPY public.auditor_progress_aggregation (master_pub, last_wire_out_serial_id) F
-- Data for Name: auditor_progress_coin; Type: TABLE DATA; Schema: public; Owner: -
--
-COPY public.auditor_progress_coin (master_pub, last_withdraw_serial_id, last_deposit_serial_id, last_melt_serial_id, last_refund_serial_id, last_recoup_serial_id, last_recoup_refresh_serial_id) FROM stdin;
+COPY public.auditor_progress_coin (master_pub, last_withdraw_serial_id, last_deposit_serial_id, last_melt_serial_id, last_refund_serial_id, last_recoup_serial_id, last_recoup_refresh_serial_id, last_purse_deposits_serial_id, last_purse_refunds_serial_id) FROM stdin;
\.
@@ -4963,7 +11966,7 @@ COPY public.auditor_progress_deposit_confirmation (master_pub, last_deposit_conf
-- Data for Name: auditor_progress_reserve; Type: TABLE DATA; Schema: public; Owner: -
--
-COPY public.auditor_progress_reserve (master_pub, last_reserve_in_serial_id, last_reserve_out_serial_id, last_reserve_recoup_serial_id, last_reserve_close_serial_id) FROM stdin;
+COPY public.auditor_progress_reserve (master_pub, last_reserve_in_serial_id, last_reserve_out_serial_id, last_reserve_recoup_serial_id, last_reserve_close_serial_id, last_purse_merges_serial_id, last_purse_deposits_serial_id, last_account_merges_serial_id, last_history_requests_serial_id, last_close_requests_serial_id) FROM stdin;
\.
@@ -4971,7 +11974,7 @@ COPY public.auditor_progress_reserve (master_pub, last_reserve_in_serial_id, las
-- Data for Name: auditor_reserve_balance; Type: TABLE DATA; Schema: public; Owner: -
--
-COPY public.auditor_reserve_balance (master_pub, reserve_balance_val, reserve_balance_frac, withdraw_fee_balance_val, withdraw_fee_balance_frac) FROM stdin;
+COPY public.auditor_reserve_balance (master_pub, reserve_balance_val, reserve_balance_frac, withdraw_fee_balance_val, withdraw_fee_balance_frac, purse_fee_balance_val, purse_fee_balance_frac, history_fee_balance_val, history_fee_balance_frac) FROM stdin;
\.
@@ -4996,7 +11999,7 @@ COPY public.auditor_wire_fee_balance (master_pub, wire_fee_balance_val, wire_fee
--
COPY public.auditors (auditor_uuid, auditor_pub, auditor_name, auditor_url, is_active, last_change) FROM stdin;
-1 \\xfa3cbcde17b7eb2464ce6748d3c2a01d554a293a7df671aa6aeec13661e895f0 TESTKUDOS Auditor http://localhost:8083/ t 1638356914000000
+1 \\x38eb29aec4a464f408e49a10f271fc9d7d49a346a6b2e3463ec9b8c00629f44f TESTKUDOS Auditor http://localhost:8083/ t 1655640374000000
\.
@@ -5061,19 +12064,19 @@ COPY public.auth_permission (id, name, content_type_id, codename) FROM stdin;
--
COPY public.auth_user (id, password, last_login, is_superuser, username, first_name, last_name, email, is_staff, is_active, date_joined) FROM stdin;
-1 pbkdf2_sha256$260000$letq19bXadlaHoWSFEuxmy$aXnWIfiCVeHVJf09R8T+FShPtObYSF1Y9gverSkElgQ= \N f Bank f t 2021-12-01 12:08:28.4642+01
-3 pbkdf2_sha256$260000$mIyB9Rg63QGEGzwm63hrJU$0gMEV5FWd+ho5LVhjBjAT1iFddhQGZIIi4QDGnG9eWk= \N f blog f t 2021-12-01 12:08:28.715205+01
-4 pbkdf2_sha256$260000$dhgKBUvLIMyqs1ZM6i3Y4U$jxhUoN/crNVaMcOu3N0e0ZvQkiZHeTs39GK7nHfjGgM= \N f Tor f t 2021-12-01 12:08:28.833414+01
-5 pbkdf2_sha256$260000$esmZPL2jgshidCKiU7hIjo$lDWvIym4IVTUWIW5fnZ3J64elTDo3ZUJo2+0SDdoh7A= \N f GNUnet f t 2021-12-01 12:08:28.954942+01
-6 pbkdf2_sha256$260000$GU0WblgCUlMmoTTvDQfN3i$Vzb8kXPO+Sb/nLB4n69P7XziHw8iXojyi8UyQnNwW5U= \N f Taler f t 2021-12-01 12:08:29.069344+01
-7 pbkdf2_sha256$260000$d9QovDC5Pv1rDLCng6JlUw$P75kw0ptunQ2uvcDtuUthrDudyq5YNx2w6fe2lMetYI= \N f FSF f t 2021-12-01 12:08:29.186117+01
-8 pbkdf2_sha256$260000$TRA2E375xeJJFNp8OX4Q1s$k693S9aD4/KBrX1zjPANqLph0deaZDXjsr78HNsfRsQ= \N f Tutorial f t 2021-12-01 12:08:29.300074+01
-9 pbkdf2_sha256$260000$4sr1dZ69tJTvCLxVwEhVl4$UEThXQvbobxzE+kwJzKtmzwkIGw+Vk21cQ9iZx9HNcE= \N f Survey f t 2021-12-01 12:08:29.415324+01
-10 pbkdf2_sha256$260000$g49r7ACpirnYpmc0YsfCTn$3iVVFhIZRQwVk/ORGgotGIu2eeJ4g3cSDpzne2+YgrE= \N f 42 f t 2021-12-01 12:08:29.844984+01
-11 pbkdf2_sha256$260000$TDta3lixvnQMagolTOJz7i$8sfprB5ujs0jTCJtjkpGQjJnr13WQ/PtqG9ykmw/k14= \N f 43 f t 2021-12-01 12:08:30.269862+01
-2 pbkdf2_sha256$260000$mHdqYFFgOubxxnaoXP6xzM$TgxmAhbGh85neHKSqyF5kt302ItEtFkwTFxmWvykzH0= \N f Exchange f t 2021-12-01 12:08:28.587107+01
-12 pbkdf2_sha256$260000$qjC5bAJyGnsYNCM9EUGSIi$4bfRzD+DAyCM1bf6fzKxwAy6ASMsu2/SuJi08ybkqWM= \N f testuser-7tgipbkp f t 2021-12-01 12:08:37.738719+01
-13 pbkdf2_sha256$260000$feG2TTUagptXYjbgMcQ0Uo$j6Cv1dzDkMa0RBGvcgRsbthZ8EtLnlyg5NB5dycoALs= \N f testuser-db6y8s2c f t 2021-12-01 12:08:49.946975+01
+1 pbkdf2_sha256$260000$pcpbRoDT4RG48YNgFpZ1Px$gxYivSss9VE7VWTO7nu0/k4/Fo1LGMVjhAdtP7cvRss= \N f Bank f t 2022-06-19 14:06:08.27175+02
+3 pbkdf2_sha256$260000$LlkPhswpnWf1lcXeNjw7F3$5CMiNC48CHR398j50/yZObaUdVORXWbsgjwByLERFu0= \N f blog f t 2022-06-19 14:06:08.455085+02
+4 pbkdf2_sha256$260000$YQ6RaehIWOwvMOmg97nJiG$GDdm96J0SsTZS9TdQ6XBd4uh0M9cY8WJNgV9cJjBVRU= \N f Tor f t 2022-06-19 14:06:08.546014+02
+5 pbkdf2_sha256$260000$Bbfsk4StqT4rZVzfDUtAzi$OFG/u52Wa7nvdAAAXlfkNSrxpSEvP7EXWfExxI9UQTc= \N f GNUnet f t 2022-06-19 14:06:08.637378+02
+6 pbkdf2_sha256$260000$iLn9Zz6Sci3B6PxjmlZOP0$iwGWeu0/yFqGSeS8E2VKHHyvDnq6TNkDmrC27BX56B8= \N f Taler f t 2022-06-19 14:06:08.727175+02
+7 pbkdf2_sha256$260000$y3tQCIVmtF9lSIZWMsYjmN$m7EnbugicRTyQCgzIZFNtXmNmHRmwDFgj3yYiKZf+1A= \N f FSF f t 2022-06-19 14:06:08.819347+02
+8 pbkdf2_sha256$260000$Vtf4mJKjXwgOVgC3tL9hF1$5ijyctqb3Ma7ru4rLse0/zhrqRNKXiqU/9L8lQZD4Ro= \N f Tutorial f t 2022-06-19 14:06:08.912558+02
+9 pbkdf2_sha256$260000$eLzhn8z4Cl75ZvnuFWUiAb$9FoFghWMvcQb4AwE4cVzUcfdcwxkxYEPeizplbQSrQc= \N f Survey f t 2022-06-19 14:06:09.002011+02
+10 pbkdf2_sha256$260000$jhNoBHQL9wqMA2jNVJfST7$e8L/3T23PhUlN628d6QRrN1HXMJkGRPZu79aQSMWTGI= \N f 42 f t 2022-06-19 14:06:09.45234+02
+11 pbkdf2_sha256$260000$Jk6SLrSajOSkNcy7hW0hjA$rYKO0oJBegZRi5oc8kqLMK0HcK68l7kvbYYvOTowQRE= \N f 43 f t 2022-06-19 14:06:09.911245+02
+2 pbkdf2_sha256$260000$UVpOACZUylhTNags3wzLnC$ZZO2K9mysdtC2jFNfYgBlchQCy46Uh2+C7zUaYPrJN8= \N f Exchange f t 2022-06-19 14:06:08.363938+02
+12 pbkdf2_sha256$260000$SwmEE5mbf5UoIsNid1htpM$xXRHpVXKgjHOX81oMC/fAbL+Mh4eb68CpirZHwKE9ZQ= \N f testuser-gk6lkeb2 f t 2022-06-19 14:06:17.06455+02
+13 pbkdf2_sha256$260000$bzKAIysOtJxIPtS2t59N8B$6MR15gYeU2MlDgd5viLMvo0K1yXwsiWjywXxAcQn5Is= \N f testuser-bbpholtl f t 2022-06-19 14:06:27.670786+02
\.
@@ -5094,6 +12097,30 @@ COPY public.auth_user_user_permissions (id, user_id, permission_id) FROM stdin;
--
+-- Data for Name: close_requests_default; Type: TABLE DATA; Schema: public; Owner: -
+--
+
+COPY public.close_requests_default (close_request_serial_id, reserve_pub, close_timestamp, reserve_sig, close_val, close_frac) FROM stdin;
+\.
+
+
+--
+-- Data for Name: contracts_default; Type: TABLE DATA; Schema: public; Owner: -
+--
+
+COPY public.contracts_default (contract_serial_id, purse_pub, pub_ckey, contract_sig, e_contract, purse_expiration) FROM stdin;
+\.
+
+
+--
+-- Data for Name: cs_nonce_locks_default; Type: TABLE DATA; Schema: public; Owner: -
+--
+
+COPY public.cs_nonce_locks_default (cs_nonce_lock_serial_id, nonce, op_hash, max_denomination_serial) FROM stdin;
+\.
+
+
+--
-- Data for Name: denomination_revocations; Type: TABLE DATA; Schema: public; Owner: -
--
@@ -5105,431 +12132,431 @@ COPY public.denomination_revocations (denom_revocations_serial_id, denominations
-- Data for Name: denominations; Type: TABLE DATA; Schema: public; Owner: -
--
-COPY public.denominations (denominations_serial, denom_pub_hash, denom_type, age_restrictions, denom_pub, master_sig, valid_from, expire_withdraw, expire_deposit, expire_legal, coin_val, coin_frac, fee_withdraw_val, fee_withdraw_frac, fee_deposit_val, fee_deposit_frac, fee_refresh_val, fee_refresh_frac, fee_refund_val, fee_refund_frac) FROM stdin;
-1 \\x029c7a06bcdd58acc2786a8db57b359eabefe6efa729e49fad583b160e6b40b4b1eebbc71eb11424fdb1fe5caf5dbbb29c29bd9c2a8fb5d7bb61cc3ef161f37b 1 0 \\x000000010000000000800003c44f782d431d1f8f2ff3ac13cb6ccdfef2354fe756682ccfdd2715d5f5e15d0b83c8517f16988d0598ee8f144b3692cee91bed2ef7bc690ef13f63e97bd721fe222a053d2434dfc459d971f289b9bfce456d3d60704219bc1b3d1a14c0e91ac0bf72872d2ae1c4ec6e0131c3958d847c5e5324c496ff8747d444bc57741d7f39010001 \\xed8307c77d6b9c176abeac7aeb5cd5641a1526d65aff59ce01a8cfd54dbbef7c1ae81fbea3c7f570476885b6e484705fb5982453a8f59e9284f62538d7717a0e 1658909907000000 1659514707000000 1722586707000000 1817194707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-2 \\x0200ccb719045dac20c040dbabf40b6be55382692118b14b0493d0ebb849f3040b73a60b722fe2cc7f8da423d3bcc6d9b69722e0eea6679d3007973822a4705e 1 0 \\x000000010000000000800003de45665b1ac54873f32afd45a8c352088df710f8d1b3a571a50f8f00e70d7535d57a9e35592fdf9d0cabfb097449ab33f3882d743894c1c70c691c7a5f546929fadd79d96c66b48171942a84d9e066e37c91390fb894c76bb84f4eb43d538d583f15e0ebb1c21dc1bc3e6ffee08e539a1cfbfa790b6c340089f8a4c6d9576ffd010001 \\x89bdc199a1c309fdf7465b732a19c6db5950e474ca603575fddb3e23a4551369e763b227350aa4fce44e911f24a5e1fa437fb3284f1df052e9e2f88502e45c03 1643797407000000 1644402207000000 1707474207000000 1802082207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-3 \\x07784278bd17ede8568100143d622362c356038aee9cbbe0f79996d70407b43874ab788a56da04c8e37fa630182d1b61f552995de97c23a8c0d0ace0cc8e8b8e 1 0 \\x000000010000000000800003b3cb194ba9669ef19b30bc437548c8cbf5e6a7f2bf66e6230d051c9e6e3f87030e6a336a0252ee068879e685df58b06486edca567ca3cb8fe9339cf78eb2c330ad03f1a6285e47c42ca5c267fec1c0c1410bef95d545166c7389239beabf92894736b1a766ac97fafaf3f470db9cb3b3dea1bba6ad77dd76e94470698c01ad8f010001 \\x31c372a71bbf2b56dc3a6d8aa621e6f81a58b9c498d5b26fc80717aa1ff75fde57dc004dcdea301663404bca256e68786307e15e013a77b79e9d538ca0a4a70a 1657096407000000 1657701207000000 1720773207000000 1815381207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-4 \\x0a5c5a18d4499dc81d5aaee852bee118b405c5670a6c3b5f8497e59bc5c945bb1b05bdf16116ebf79272f0d29a492ac32c25840ebaecd1d3033c12573d62be7e 1 0 \\x000000010000000000800003c5527c21afebeabae11e5629ed15bb62f9e0ff457891fcbb195bcd4edf206c4b8e1811425fd6ad50a7a6f55875337399991e2de18568f1f7c7354498643384dac6d619d17a8c94e9c7d1f85c9e739268ad3e7ea7bee96813df8e102847e04fec7d986c2d2f7631dad0cb708bfbee1bcd82e9661f83cf08273286ec370423c6c3010001 \\x028f25536e5241dd4f42ff588a833a2a1ae8e6ba5969eef0a03bf88c1f702d66c2957a50997db576bab3b95a5937ec6392e5a4f61ada07522cda35970c367804 1648633407000000 1649238207000000 1712310207000000 1806918207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-5 \\x0e10adba8cc4a6b6489b6908363f2696a4fc8d48167f25a0c409046bd93aa47cf7d0681165dbcabee127245eca177a413e51a9c8ea4075779396eb21fecb3596 1 0 \\x000000010000000000800003afcb3b7f4fb0daa23dbea00e265a006c73dd91262b722dfd48831ad28bd9f193158ec17518d3cfcf4c659339cfef8874294819a34cc925c309dc124c601c63453872cec70369cef65fbad24f3d96aa0166c244a4fe8b0e18e0bff5af74139adc0946845dfa6d4db4e57748fa3176f00248cc9865938b346b813a53fca372173b010001 \\x833616613581c8ecaa24706c12b35a00d4fefb560501446a778e533bdbcdfebbd70eb0cc1932a185949b763202fe1a108c0e78d4322c4328b5d6d83d496a3508 1667977407000000 1668582207000000 1731654207000000 1826262207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-6 \\x10f0ade480faa4c987ebf6517206027e3a311b807b4d3d3070b67d70817417c2d1178ea5c82a07883a0e9722033d8acf780662e753b53a8167fbb5ec8edbdb39 1 0 \\x000000010000000000800003bf4c01faa86becf60793237fe303127eb392485c08ec70ff2197c4544b6386123755e8dc1078cc611d0a5c9112aa22ea770e1c36000425f677bf9b69161a6f919c24a0f345019ba8d906f7d73e9f9924798eb375973ddc29ebb9b29abeba7064bd4c0deb1705d1b8240cbba1fd4194cfa94c23e9424990b7339a79ca1ae940b7010001 \\x2d5755cb60a33c37c59200f4aafe84e5785207b8c2eb7349511d6e2eb2a87f6b053c96902ef094503d9a662892742c2b4a6077b80a73d101d72135473e327d0c 1638961407000000 1639566207000000 1702638207000000 1797246207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-7 \\x1328c3ef43f0eee88ec7aa178f50c963801d312680652916464fdea809ba7b82408cd67f1f3d43b3256393eea2080721dbfa2483baf3ac9f127de0262b3acdfd 1 0 \\x000000010000000000800003ad8a782dd66375138ed179da36b76159787f8bd1055cd61866fc4dba010da4f28d86392329dd3f9b0c4af9c79243e098dc93d17222b0c905720df3232ec0b0506248438720514b85929657ad4612038d0d0fec0d9faeec01d3668762e5e1a0d83aeacad835b10d5958e6807da57027560109a5ba92989bf2bf384da2e500e80b010001 \\x187700207dee671ddbe110274305cfb77d59903ab7c69bb94a6151bec4cf330ed1c01f84b746407bda35092f143c636631641ab3aeac3abca7121d08c3e16d00 1666163907000000 1666768707000000 1729840707000000 1824448707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-8 \\x1570e7c259089423fa51781a88835b0310d72ac346de645de6cfb7ac49c4965cd6148f613a7dcd02ef8ecabf0aa25e8a0c170848b646abd5ac217368d1facf1f 1 0 \\x000000010000000000800003d3b92f35df645721f2b2b7c4dda5bcdf32074ed0027a06a71a04113caee9e41ce2f2cfb195b623263d43d6b7a06f7196441d59f9f36a11656a5cab5d16d228abb71a4e78300d3af81bb524607cd1606fad7eed9f892545c3ab4cdad521a7ea75c31f2a2925f4ea08f1837c18b1b588515fa6162e7103bb7ca5910a1d9338288b010001 \\xde4f2ec41b8926fb60fe5f1d23d8cc20d89a0638172ce7af1689e8c7ee36dd427b14bb03d6475989518971d94c15801a56e83ced74715cd92e517a0c36c7cf07 1651655907000000 1652260707000000 1715332707000000 1809940707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-9 \\x1a84d06a28b27976400964450bf661c29459b09df3e2bdeca1740c8e3f328e66cf51e1452767bf6b1666bd93390a5ba00c35fcd2730ab1d7aa0dec20dcf21c80 1 0 \\x000000010000000000800003ba4b64370aa2becfc56021444f919705dbfbafba2c2ec7f756249072582d149f3903890ecc3ab4cc7ef12d926faf30faefa544b0f71a48e9c1f25fa252079f96fd15620814957d761ec1c23b8cb39610e4a8b66aee6e8dbc5aca5a4cbe9c9d6ced10e551aa02b690590daf73d60943a7f367af7729255c72e4ba6ccb0ef88107010001 \\xb31e6e2f58dff0a1f4c8be94b7f2c40146ed79d5bdb1e6900e6eea83547017f17786584760c0a0bc330eccc5d78d8f120203f2339533520eae7598179d523c07 1649842407000000 1650447207000000 1713519207000000 1808127207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-10 \\x1cb0cda243429d5aa15bd42db21f079fd6e34089131828a243d11c2128c446c22639d1a9a96da71751c073818ac279c267508a6e87f1406e8b20fa5c1aab1342 1 0 \\x000000010000000000800003b9e8b2f0fbef44aa39ba01b1f36ce55415bcca6481efa4606fa5cdb7682ba8179d3bc81505b217bc1e4829110f43e706021dd40ebbb5afa991c15c19f52cb6b6f5ab117392ebc3aeca99695b2135b083520347d6d6e5e3fbd68e2550473e3d323027214b43df7f680534c3a9e9a6621b97912df3ed1cfab5ace88d85e2b80ac9010001 \\xcf656fbbfd6a083483d8494b1498dbf92a28f5d8c44e9881cb435eb9b820e45f494dafc99b96f8a77ceb9fe9d7e2f56f0a8acf7f78a4b6b7adaf4c35483bda0a 1643797407000000 1644402207000000 1707474207000000 1802082207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-11 \\x1db85ea12280687e27fcafbb13152104bef3ac8c209094e1eb277f7529049f0c7eab7457cac0c0d2d059a6f5a2d3848d1528a5b5dda5b921f51c16bc7e3ad597 1 0 \\x000000010000000000800003b978a37809aae1c16c37fa5ac8bc242edb827dafbd403a530ea3dfc7c9b2312b91e70ffc083d81fc865e1fceeb4087dfd47e68ba5b1d928d2ff6de124afca461b573d665f320a4f22d641ea393ae194f93d175c2e5c3f683d00a53831e26dd4e306ec674e270bc4fc47ad4440dc4ec62ef87a60526a318c933666bff8120850b010001 \\x4294d49a38ed84b67cbc9030e1b6914e9870609aff5d3698753a297622a3100cfa01f024d7dfd27a5e483d4fac4b8791587324ac22b1105a7d91f5ceb634840a 1645610907000000 1646215707000000 1709287707000000 1803895707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-12 \\x1f9cc3ee27f1d77c2f1662f9ede073090282dd3f7774333a82388f92310bf8fad73e1c8eaa14c738795480a2e05acddd9ea1a930d63785e487681215344b6700 1 0 \\x000000010000000000800003baf685cc634c67cf3a93dd580476be6fb116cfd2c58018d9a2fb6ac6975af23230c55aff714d53cf91648b43dc3c6616d19ea0ea8b105541b44bcb218b760cf9210fd249dc42fc247e21f6c22b584e9034636e9866a4a2d81bf4c254d8ae23adcbae80e990cee609897dc0d1f9c1d5c0886c45dea0326cd01f037859d9fec889010001 \\x2ddb6ee066d758959837fc2e277ecfab7657666a92526eb0a373e46cabd2f9f4b553a992432aca705e0cf2cf7f7018d0618f6d416f72b50ccf59abd54039ba04 1655887407000000 1656492207000000 1719564207000000 1814172207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-13 \\x20dc47eb80b47c6b37d9df7078c90907cc3ae6089fe9cfe3dab8d5a969f137ed7f7d58e9c03aa293759aca7f5bfaa3229e4ae1871698deee5a0a67859a4fb721 1 0 \\x000000010000000000800003a80b9e1bb5699056cf9f6fc020011b18ee3ece1412a4675173dc453bdd45c1a73d20e5a27bb9c76be741a3027531277e24605c84797901d0399ffb11e1eb1119469935aac4529773d86f9aa6c5a5ad0b70d384caefe8703fd802a38e7feb1f9e3fc2842075eb685c8b5fad7a85eb56b9d01952bde4eb4b25151b103a46faeedd010001 \\xf943d12f1bd9b4d7efc12e2c454ad493097b4a75300e01e805186779790ec2fbcfc95e416cee2ecd69ec9f1c4566e7c75c7e9c94ac491497ecadaa0709693704 1650446907000000 1651051707000000 1714123707000000 1808731707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-14 \\x2274f7316b666ce563edd9b1d9c3da2aea20fae1a69a7335cfa693f4090eb3a2d19971e2581061e4d6d8ed5eec3e9df763e3a3085fb6bc251de8077fe754e68b 1 0 \\x000000010000000000800003ca2faa67e1a43bf12de98b33292a57c5ced81d75d771e776b61ccf6ffba56a0fb9ad9bf8b730d1415033dcd455db2d0ef1710cb81ab8149e21c52d56f414300190d5fc4a41f03fdefb247bd4c6e72cfc087276134365225f8a2e8f60f5241069da3f90c28078f71425bf7909e8eaa95861e97358b7690da320763a9dcadfd821010001 \\xcf1f7db8dd0d5fe53e6e05dfecce2c5437ed0c3add3c74b35c96e155fb0dc7fc739373edb9368efa6c056799a3554a9e53e88991c66eedbc6867a517d5e5ef09 1661327907000000 1661932707000000 1725004707000000 1819612707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-15 \\x22bce690adbbd4b4a5fe9919e4482a593317341dc37821340147d13b9f10c72a3b43e3edc042388cffc03dbfbc2a015f2880464d76a5777befa0546c7bc854b5 1 0 \\x000000010000000000800003e87f94ad9c14978ba72d4b72a01f0a16012883b3cdfc57a3f87d4b9e7a43aecc3c0ff360de96df0efab9625dba6b4e5d4410bdf182609a5c37c753f9c08a218c985f614ed5acf71d9c8b43bbcb6c31b859a2a04e62ac41b842af11dfad92aede45dc439d6d486d2d79e30f4f36100848770df13f2767b20f36f4db20205821f5010001 \\x6febbd0d4476509582c766a38dfc5c7baee9024d9bb8d07926cc1e9d00a1c3679107518a9aac41cf0dd0883d4d4e14709fc3a831daba7dd7cc5526034399ee05 1654073907000000 1654678707000000 1717750707000000 1812358707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-16 \\x267883b9f6d24047d10440c442290b71f20ade5d3abed0c9073e1fce98e1222457dace466887385ca5fdb3a1d37c176284ba0790486f1a91c72fe91fff1fd737 1 0 \\x000000010000000000800003a91218506ae211a73992b455f81bc5cdddf868598dae344a796219cafed5815285b70b82ce23af24ba3922a682573af7bb4ba178fc6d3e2a620ad0980e53e037eaacfdebe3e85a573b213bdf0c7df0dc444f3f06bcdf6c0a33c1459f36a15f60a9506763a743d6473b631d6fb3684ad346261aa5abbd1730e426d2a5b071eff3010001 \\xf651a0ee0a15e9eedfcd5743dbe1731ef7490b6cbd82d754a3d2e5ccc73d1e8806921cfae15a388ae87da10b9daa5be65272fc047e5316402fefa075c1646b0d 1641379407000000 1641984207000000 1705056207000000 1799664207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-17 \\x28d4a3a532603c9293de7b7c7831633032e592286540aa8db82d6fccbbaab92bb9c843ee56584f22f19477d61150aa30a4271386fdf9ae5fd4c428bf5e6949ac 1 0 \\x000000010000000000800003b5d182cb437989bbb137925064aa83be4ed89179bc0c08a17ee1198132bd8e91a51c28c07745364e23ee2a8b42521debd9b2397b09e3c7cee4411dea88ff73f1282e7d4b761512d20bb9e14cdae3ce0624f5268e9734ea344a332fba28ae65d22ace6eb5deed37dafe46d35953ddede92d18f1e38ad22c190decccf2bb972e7f010001 \\x08b503ddb2d544ce8da3b4eb0905d1e74c422966a12ebfcde6b525bd927811d33407b50d4ae316097ba397c037bc6a474ea36e0fccdddc9f533809a6ffe55a0a 1649237907000000 1649842707000000 1712914707000000 1807522707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-18 \\x2920007439af0e3f0df5988a72b44a8ba160a9618887981c9f54a681496c89f732910984ffcde03aa32f456c4e67c3c024e2b2b61706ce843247cf885364ab7a 1 0 \\x000000010000000000800003c047ac777cc432102cf3eb4c75e76a6d14ac255807c7bb913401e4edc951bba358fb0d6158ac5766d1bf550e0763c35e790a2cb5b119f53d94ece2076fab4cf6a5b25f55337bfc7960ac3d4fe716d9ad3b30a86432043b39f049e7211a77f48e0deacdccf2208b8c1377a053177753b97ede1cd02aac71573bb9674f29a6305b010001 \\xd134ea18878912318c93209a0ed195e5349c0f493ac9cda981377870c6eecf996871fd6229595d66f6aea40dd4660b325bab9a38d3f5d9d5b39a935b39aa510d 1648028907000000 1648633707000000 1711705707000000 1806313707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-19 \\x29506ef959d47bc600708cca837c1e8b255b7af881cf7ad3d98325939ba6bb29d2a31236dfa063f7e97ef387bc2c822216735418803d5b7d0ad85f08fe41da0c 1 0 \\x000000010000000000800003ca2c9934d35c87ee536951a9b7e67aa8e31bb953ef2ff1ebe33de8641a6e144b3bc1329c1cb8a0dfde85f575f07f0536c5b9f4c5e4c96590fc3ff76e3ab9b204784ce828f7a3d31e53eb7815b9c819d376aaba0917373fec056b21088ec1a84c1e7b821092ab4fe7a7a003d286effd9b82a9be7e6add989f76ccf81f1aa678fb010001 \\xe37651b918cceb7b58c84aaafeba867451f1ad89b22a098d530170bf0ab2fdb87e6e6a5a3da8f95d1e35a237f0e18b64101a29f62266579f67ea1d463c8aa70b 1639565907000000 1640170707000000 1703242707000000 1797850707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-20 \\x2d702502804870c04cfdb599b33ad9fbfa607f4ac5e74b13214415bba6a857e1bc6f9baa1c47dee1331f444675bef062bcd865d4395e67a6ab44df235edb5b76 1 0 \\x0000000100000000008000039f2796ec4a822e9be3689526972d2fd608a792aa533917555d2232bea056b5aa23119817915fb2031de5bf73794551bcec5c1a60f4874440e6e149fdf0d1eb0b3dfd1024598faae6eb2428c1f828ea460754613ede2ac60ec36ce5756477e565bfb1a116058987772d6999eaa1e3e2e4d4d45f111d6d335149c127733e463673010001 \\x35e3df148786cacdec7cceb400f4ac0c87dad065b52e239f6c93ba2356c01795d70c8173660336b2e109a6e6846cfd7110b8189438f13871ff37cbf8a4ef0f00 1667977407000000 1668582207000000 1731654207000000 1826262207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-21 \\x2eb4d2c63176b458850cc47286bddc63d2f6a899112df92beecb5cbb35ca7925d2d155777dd51c2a33d85d3b9c21e66b19e1fa9bd91dfb08c4975383983895ac 1 0 \\x000000010000000000800003e04c8b61f88d41107f81cac79e50b4682dbcbd84da8f09fc4ae718912e62ff9af104bbbb6bef281e81fb6a974faf8e4c82bd17ad20f9bca02545e0e45b10840447361bdb3a7743b7f8512e8902899dbe5d737f537325d51fdd96a858d785816b1bd86d0b0935460caf7a33800ae447877393d7edc60a8e922ab6533d0c10d177010001 \\xd67773d4ead4a937ae7880e2dd0bb27a98b435b41b0343e017f2d372bb0d454dafcb198631757753378ec218e91ab35dcfe069ae46b33604ee2c16f56000d506 1640774907000000 1641379707000000 1704451707000000 1799059707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-22 \\x31f8bd40f559ee4ff722a7d9f548135993223db9bf1594ececb9e2dc1174eb70472f6a5f1f6616f0ef265a3e44c2a9dc77ef22c8f8f6fa099b4332c46692c4ff 1 0 \\x000000010000000000800003e84fdb034945a3d421a7cce922dc22f563a2ec7539b9335b7428984a01bcf7d083b863f3b9da9440859873a42cb70d68babcf4d83a7844e23da73c854d7414970710efb58f7cdbd1bc08196df9a7972d1a9369f5b16345f63fb5018bf501fe205f241bccdbf28e8b7b62be875fd9f9b135b7b10e7461a4bdfdca3ae018c535db010001 \\x44747292f7a16c85d182290f267d28a48dba1623e99f4dc8c5cb627e878e67e6952b70799439cb368c45069462a296f2a0ff3b6746d2448bfb5704f96cd2e60f 1667977407000000 1668582207000000 1731654207000000 1826262207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-23 \\x34482eb9de9088a0ba2beec0911755cbf0ce43b7663fd15355197d49bfaac4126a7de1fb41cee390f44b464441518355a20624e39bc5a3a3fca18fcb73c7bf83 1 0 \\x000000010000000000800003b2f6fdddcf853b7ed6b92bce9817c637827757003822ce61db1210f2021fd5176a2fd88f9f22a06653fe7dc61e6dd3ea868be3e45144134a56d0a75229b0547859d98e5d52073db8fdbda3530a0bb000b52594824673494263d4b141209d455faabe02a41cfb88604d429ea884cba761eb904fb1e35d6be25ed4dcd03ece48ed010001 \\xb2585ad3b478e3796444f44c9335e88e8d3cf66618280c849ccf1841a11ff7f26d72c18c5610459d659fa3da4dde1ee77ee7184b15c55ca9cccbdc7b43df1801 1666163907000000 1666768707000000 1729840707000000 1824448707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-24 \\x3590346b4c2dcbdb43535e39f92b61a5535a59a786bc0c64d4c8cd874a77e200de5f9e1276a69e5d2a52a983c6263e4f88dc10a375aabd0c73901338e06b2aff 1 0 \\x000000010000000000800003b3cad9157576c3c6b835c4ce2421150c489ac1b63b220e7c675c2da7fe17bcb038df428fc9f0bc86e3ebf1443b14bfa50856b7f10ff1f485fe5342c4fc6fa51140861f3a4131156f0d799094ec3983dbd21ee1737687fbc960103e3709eb7e70f39054cd323c9de8a0150c835180c128fe51764b52b3043c2ad7bc4e0f2ef039010001 \\x34478ed0fef6e60fd64241243a048669be7dffb4d555b9afcf05ac4379b5b48c6e0255c37f03b32f94bee853062b47f8544768e07ae01c5fb2105adab2556a06 1643797407000000 1644402207000000 1707474207000000 1802082207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-25 \\x37a01e2b494e11396eb2b9c3d103e9f13bf9255c9d78f673ed430737770e2e857190abc9f8993a8d62553e2fe6b9c4f66d0eb59e9fa3fd93f1f21400b801a90f 1 0 \\x000000010000000000800003b47daa07a7c053dd6b5178a39b46544bf289c9e226f1f62e7718ab6647d98d3597165144ea9a8af64ac57d04cbc818ad67c497193bbc5b88e11d64dd5fbeab115a4de65a98372201f014a71be5397885a76ab3475b6f64e9e206365b5119fa5dddeb1d01e3fd40d5ba7afec206831ab6b26b97960874b093af26e9011505b717010001 \\x08ae6483857f11add615035e48b3e7d7d8cbc3af60bfbb9580152a1a8a98ade8e06e720973b6344f71282d6e3f6b84442efcb2925226c6834cd2f2ae36e75807 1648633407000000 1649238207000000 1712310207000000 1806918207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-26 \\x39a43c3ba43138b0eb46005721d6a301fe6abac764cbe2c518c470056e66c72f67ba6c10ba30c413a15c1573c4f8f596af68a05afd25390338bf771355f8f713 1 0 \\x000000010000000000800003ed178667d0b8e45c3aaad1b8b0b1b4d80b83ae78b18ca589fe0d57c57c7edd34feeb8668c8e315852a512714a17eedf247774c0098ebd458af6b62242c252dae109691f5d1f3d1147259743dab0597a081b283b0e724bf1368541eee760fbf9c8d81e07e560c5206380e9e7298779992f1cc1b945819aa44af43f66f03882dbb010001 \\xb630be56e269bd5cd1fa564fb27873d6f7d0bcb04b3610aed69862c5a52e6ae7f8e0ac7b491a2b579021e76577aa9f251c6222252755efa95250ea93c86acc0b 1655887407000000 1656492207000000 1719564207000000 1814172207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-27 \\x3974d3a3e1fa85f79469313da20cb4e9e6b7c3c77cb462c4b07b1f196df80133fe71403dbd222bee832a27283da418144a36fc9c286d3619c780bd06e597e44a 1 0 \\x000000010000000000800003e80b07843edfdce76e7b0a6c1995c1b99e2955151f41e9dae1a2fd61cfc624545d5864779b4862aaebad8c42435f229e5c46257ffcdda381b60c19c90396de00fdc76a109c7880ece73e1d9d7161dd47ed7b33e2be46a481b35a2996a8d13b8d5539a3f1aa3e13a3b37eeac97c01e56cc6c30785767aa411581ff2dda43b0581010001 \\xc2fd01512536eb325e7b42665f38c5623d3915a241a6a87bf96b7fb159e8a65afe0b21a3b3d48ce6a0ec695b85c278381dffab8cace0a3a286d114b8b472ed0d 1644401907000000 1645006707000000 1708078707000000 1802686707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-28 \\x3ce896519d7a46698b8095ccd51c43a29e0cafd17e56bc667ed9ebb74d0f8659fef5dc82b9ea0a78a57f0c5e1a7252172ac3f9ee3af734d781811d8f20a9bcce 1 0 \\x000000010000000000800003c730b00ca5e63f5d68dce9a4de37fd3b2d27f95c021f44330c6ce8af7783612274be46ea7efa6a59d22d1c8826dfedec357f32c73f360ea56fd3773dbc39262c0a57551929457426c66543f8b0d71994072e1f95d9ae82202dfb769ec90e52ba702c880f427b79a92ac773a60aa9a58999ff696f12aa3939a90bf429e4e0901b010001 \\x61d628af1c1f2252854ca7ca37cbd855700ee5f1cf2b10a577d684ac682b8205000ce68c4a11a4420dfeee9a44485135dbe0917d3475a2e6e57cbf11f22ef30f 1652864907000000 1653469707000000 1716541707000000 1811149707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-29 \\x3e1ca6a3b421ae8dd9873131180f57def90c7bbb2f629825de2618ca6508afab97d76eb04a989cf411e5ca1001025d5e526fa4ee5db4134c42d9f263bded398c 1 0 \\x000000010000000000800003c841869535d3b9cce6aa48ac165f9ba44e16d23ee57c6747e67d614a497b032d63922b6b510c7da8e398242a6ef2dc62c56b04481045f59f94940048785579e76e0cc461f459b3b6878080e3c9b610f7f555681224a8038cff01eb332430b2d95ad19ef01bae8eb55a97054bf990bd60161393b59eed7fa3bb191f3ab2ce9055010001 \\x5d4f8b8a147940b53beee4205926aa513f507fe0dcda2007978ef2a799e7c2daf07e2f5c95b6ce27e9d552b655dcc51a5098499e84fe5a590a82dba6648fe108 1651051407000000 1651656207000000 1714728207000000 1809336207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-30 \\x41e88c910bd773d1be374c55c953b2529b0eecd1cd43d5a9b7421e684f73acba60a6ce8b75622e40f397ad1d2e15fadda8a60b4a34a58a84abf1e86c8b50ec97 1 0 \\x000000010000000000800003e7f6cd72617f9593484bc87d53a9cbed306997325c1e4a54ee1a3af099f7334e943bcc5842e597fe9040ccf3437aab1bab3afbb79ca9c9dd066db7e4ad44ffa5b9e97c8d3ea789172e0585469e1424753695c97fee14a0d408141bce54f4bef961d6e2465f52336e55119c7582ae6da8050f34a9a2e4f4e74502985c9682a321010001 \\x29478434ec71c1e615bdc95e2321bc2383ad79cf1827e7aa96c158dc764ce6e4269e811f7bf066d89a1f7af182055bd6c32925e1b3efd874d7760ab59a3ced04 1651655907000000 1652260707000000 1715332707000000 1809940707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-31 \\x48000068bd33a418f8950f07d8a623688a6c942e87b5c772a259cf528be8072ba69d0203ba55ae199ad37aa4b0fd3f2a63a243e8b7168a5a934f477c843373ce 1 0 \\x000000010000000000800003c9da5496622af38251582cfbee963c5bdfbff8d5eb3ec75d804a48bf000f8cb9ca5470357d6e3f20dcfe429361e4b992e2dccdca6aea561289f2df317ab212db1fa1338d8823b551bdf21418bf9f7b3fc3a2de28448c87c423da86f132c95ac15bbf88dbe47f2cef504d97e94d2c1acc6e777345903dffb672fba65c8bd0261b010001 \\x09181ab859a3ac4352b35cdcc2d96502ea0dcb397830c24a1d3c00b228602142d81a0ae41a07f4b65be9cf7036fdd353950adc25b3e9cc35d6d61da8c4f8ef0b 1653469407000000 1654074207000000 1717146207000000 1811754207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-32 \\x4b1c57e6683eb20e322a75242fccc3055bd200e25c572f99ed24d9de0101389f06610dc2afdedf041213b7a98aef61a642d4bf817b8a0bb52b6d6b7057a6d8c4 1 0 \\x000000010000000000800003c6eebc95720ba253b9b8528837949d3ff7608da2746bb0901d50cc86acc5ede4d4c2a4589ccb72d65013e5053401f3f441ddf27b508f3a7ad1d3d40248ed193de8f0470d0c2240bae799010fe39f64c46656436ae3208f5ec78f1f63be4855cf427466e1cd98e485d611eb4a8ca7ce10867d8e24f421f3d028f8f51140482a0d010001 \\x1108521e129118e8b32fdb52d4a3a7ceeca4ec92afab1d00f822c030b38548a8c712544c03f21b56abb5796dce3250870a3a4a7c7bbc98d0ca822a90b95eea0e 1652864907000000 1653469707000000 1716541707000000 1811149707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-33 \\x4c30862c37d3cd15f08656d6cdbec3e22d968bfdd8edee1d907cdeeebecc19302db78690c092fbb998a254ffd558217ec90b572f0451dbaf9ed6fe4e0f5452d0 1 0 \\x000000010000000000800003d6166c8071459318b67c8d7c889629f7f920a1f4a7b9d10ba0830de9887f0c831ba4822766f79c9255b523c92b5e720103d76ab7d43ac13f9d5f035935f5f1d7955fb0bc490109e88cb614ce045a0d5d9be94459d3fd610f2950af05e982230eb036ccf3ea9e9cbb49c511a49570f9621a6aae470ec2360ae961fdba3f88b269010001 \\x18615e0e4dbae57131a947aedb2b0f678d808f4db92aff18447f9e91f2b2dc7b050c5c863dc529ef9a7b67a80d8775e44747a3e2fcbe4535e5e1803087464d0b 1649842407000000 1650447207000000 1713519207000000 1808127207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-34 \\x4e7c98904a47a8eed1b93905d110c38a55f6e96dd43936716a9d45fad810c5a6cfa77ceb9c5016ff2d4006f03f3b5721b7e82da3600c94b8a11f9ab57f767719 1 0 \\x000000010000000000800003bbf649a2e43236d1f489ec1de0a467c7b7aa37689023f29cf6c39feffced77c37849240e582ba3ef0743b83ae01ad3057e443264c497ee32d4672973db0419e0022a364680c4d978f6172c38f86c9f2e6749aec8cf3e1d564fc8086153e2472edc31ef164cb61dbbeee4299cbc207a17604c239ffb49ac427ed9f73db6abedab010001 \\xc9046d4adb53ef5ac8e90313f2718ce1edcca65e1417930da9be05c5a3450fadcc6154c57017cb6f471570b4dc3861bb058dccd8ffca04a64a508f7c7a3b5b0d 1669186407000000 1669791207000000 1732863207000000 1827471207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-35 \\x5198952f0eb58f7ee44cbf8d2661c7b360eec6360b35280b48a884f502afef90b952958502ac64d9d28c49bc93722712ebc6f3197b97e744be61dc4fee3dda92 1 0 \\x000000010000000000800003c6961da18ea0e839d675bed810241612884568b7e49f343110dab0d7b201908bfb7751a000907e6adbc519019abbed6487abc1b7ed96239d2a4929f40d5f467b396f09231458e18d9f3742d1608315928d3e548f34a2e8aa1374d62cbf1e6a850ae0d1db7184c0547170d5d5eed0394a89fa2d2da83f212ed5b215665bc932ff010001 \\x7605270fe13299a31f6aa881af8860ca558f2ee393d932050abb81e9784d03183c77a7d063cb8e6a25fafd0a1682904f09078dcbdfc2bf8203d3f0f8b03d5f0c 1655887407000000 1656492207000000 1719564207000000 1814172207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-36 \\x513c47a9f58587e0e7a070e9c2c5d39cfa2e0cb0e569341c237a7fb967be89aa80f476f275eb849d11dec5de43bff74e94e68f097c70fbbb4c7441128b6487f4 1 0 \\x000000010000000000800003bfae1ebc13339737fbc047f2b8a7bcfa1ce14ed587ec0b15d99cad5d730e1b7b8652d5d50a1f8d9098f1372de0dd58c20961ab50a186d1bc8ef133a1ea8ea15482fb6187b018abbf62147b1ed61bc9d2f2d3003125e59eba7d3a57d1866ccd9397a0caefa2299775dfd8cc31de600aa88fdb8b4b212f9bf0c5e34d325f187f77010001 \\x8a44c1a588d7d7647c1bfa07be77291be3be607256600b44d8710a4eeaeef1b7163705b4598c5550ea411bbf0a11b331e182b450937c9975ccdd96475ec25406 1640170407000000 1640775207000000 1703847207000000 1798455207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-37 \\x529c21b4509c93676bf3a16500fcb8503a70a9be1cce9ca0655f22ec21c9175be29c797da64d4aabf79ae7d5051672d69c3ad8352400c1b75f0e7adb3d05c7fc 1 0 \\x0000000100000000008000039c6cc81207e410a107986fc0c44a32f13b5c296d87f17f824d6cb62712e694cac93d86bf2f18e23ba60aaba6faff413a0b44f6b37be571e11d279966f654274ca98a1a3b329d2794961f9cad7781a0c752892e09dfd469c2eb85e5252793ff16093acee52ef9b9fcdfd4479d4f2fa4c00a3f6e15713242341aaf6ad4dcaac067010001 \\xa68e52b2e7b5e7a9c3d23816fdc4f00e3de7bf41e57ca51c3c621e2c835dbc3f11c7d6d6fa699e25e304bde2131c9c3a0a959cedaa19c2ed872b1eff43dd030b 1655282907000000 1655887707000000 1718959707000000 1813567707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-38 \\x58f8e5de818b09ebdb9af715addb97dad0d528438c0d19136cde2591096456775cc76fb6a1fd8ddd0ad38e24865faf3f3ddc6ff99106d8ff3c2482d217eabb05 1 0 \\x000000010000000000800003d9ba0c5b68cbe17554d8f5f55ed1696ba527a2eb3b82dd2db883050b0330b17b30bbca816618166a442fa483ba4c5707d071165ce28e508e0b7d322f1c3424773fcd13aec42181894dbf2dd56877f07374895866173da420085970f650830ceb1f142f50fee20fe5f56e25b8ee4027b21d7dac91434e3465fa7c5e968caedfb3010001 \\x8081506f731aba9c7deeaae5ca028a021314c1b4344f5fafd0eaec0bb429c2e24682233e4cd121e0fb6818e57a03b0f15540c435a6b41237b0795b1526c2dc0f 1649842407000000 1650447207000000 1713519207000000 1808127207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-39 \\x59f0988c218e10395ebba3b1757d47c22858a620aa237f1fb0b9b32bccd8630b9c5e18080a0fde7d823c1bd180c3c412e273d533af2ca7403420f314c0a907e2 1 0 \\x000000010000000000800003ad97a1098ca06e3800173d316ec01aac72bbb3fac1c6d81032fad7af9bfe459f88c83c182e9bded69a77fec74ee69c6ec59115e2785bc3d17811d5d89b8b0c0d16a9f4453c6c54df5c8430371eae997929899fa29aeb6016219832c0d2fe6ce587ab3b95cb015ee8ed7b95392210107e79c4c23c7177ad42f2f944b454cf2af1010001 \\x40a8e1e8567d823f9c5cf3176759456ab745e779c5baf2d23baf83c0b9882d951491156dc7a9a712ef4a64cbfdcd533c7e9c72f2c19fbe4dc5dc71d572bde809 1669186407000000 1669791207000000 1732863207000000 1827471207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-40 \\x5ad8bd75a53c0946f6d0fc693c501b747c44dd8f0352e9a3f7cc111660bb11d4a28323724dc644e0426eb41e148cc3e8ae32ccba00b261aee24ea7f417da858a 1 0 \\x000000010000000000800003abd024d9c74dd282ea50c116647e50e0759ccf0fecfbdf928f82d37c6a6f14f2ac40ab2ad3257395b59a346c5b4b3a380ad3b35a52c2edf0c871dbb5ca1e96505e05f211fb7a2f4b15e43f99a077405dd9aa938a5ba7946f3a0283e31c17647bd0b6108129e9d6f7fb86f051fc7ea66c9ee63c20ef824828d0243397b4f3400d010001 \\xb2845f7f4483575510663394a590ec27aac74b1c61814eb9d9873ccfe25a09ceb2772903da6cfa834fe9bec83f98f1c7f2a6f46362fb67f1fb40338c8b6a8407 1646215407000000 1646820207000000 1709892207000000 1804500207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-41 \\x5ec892975b6818431f1136a04fb398161ba3e7dc68a62bb609edb53dbcf7ed237c78a6a12aa06e2003331f0654acddb9faf9210a32d28a83ea3b0242665d8f6c 1 0 \\x000000010000000000800003bff538b6039f641ee26cd984237388a70468aae4aa89b373da7bd6bd78dca4ac73b0ff590b71cadfd7e9172d249f25e6ed3c42848d33209b25ad427edcc560558e25c9c22a90e86c55983f9c2749bb542f4b6c90c64aede40a64ba12dd1beb503902dabe2525f6a8c2330d549d90ae2cce4b2b4c1a6802e9a3982da83cf2d8e5010001 \\xfb08bae3b94d566b2cc48f529a7d334b9d1c4bf0caea3f08c754b68c13b7ea88155171fb7de4d0bc487aa8603066f340ae437e20937e6c12277784ad3eff5f0b 1656491907000000 1657096707000000 1720168707000000 1814776707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-42 \\x5e9c4602884a80ddb6da2752e479b5b445008225ef8a1fda5a41bac1063ee4bcedbd76d88de648096f399b31f8aedfc893a2ae705438d8a70bd8657ea7472298 1 0 \\x000000010000000000800003bc65083451c00ae15586c36b24b7122b60f1574a9d94d7c10ba5de8dfe36a8eccd66172b3101c0f0fdd91f7794f067de46907df0516d12bb25c908dabf8a7b132e2878d40392de2bd073ad273fd9968dabd7bbe166e975cb71ff91d8b83e4be1005f6ff2ed4a02e5a4220c84c5c228875d5f4fcb838d21dd9eb7f7fe964e87b9010001 \\x920dd848a42bd62897e8ad31b0558fc02cb6293ce719c2e7294f78321c6b6cf9a1c9d7624d2f02ecd17e6015b059c0df1457fb1c238f89c706d6cb34c9975a0a 1646819907000000 1647424707000000 1710496707000000 1805104707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-43 \\x62009a52e5f56163bd4a2d8d4743bb14f078b68d6883ba3498b568a34ab2dfe2c708aa1a8e7c0ceb45d992286b6e2fa3eafc786952a3a49872d405e7af22f12b 1 0 \\x000000010000000000800003b1f0a78c36f8145849444f64f30b6d0cbcc30cca6b9571c8bc114718d7fba2eec31fdf7e64905a81f5ffecc5737ccf9d53a70f53b7df6da033c3c8d2374740ad18f0d8d1ab655161df56a52fc8850e8af04bbca862fbcf3a9a9c304f09f50485207facfae44cdf379e405e3e2bd99f5c368727eb736716f02bbe8d7f2cb4fdab010001 \\x938e11bf19730ba0c32bf2142224660fd9df93423e4996d0983c7b63a676f8099314bf3b4eb458aa91d11b37406c73401a37bfb6e8747c011ec47c5eb8425e0c 1666768407000000 1667373207000000 1730445207000000 1825053207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-44 \\x62148e2ece40c42428d8e9a03e8c2573979609dfba8d6c5632021bf848a17b1d1a20b4b5811e9642b5ba1eba585e63491e3dee45caeb36fe2b8f7723dfc2902f 1 0 \\x000000010000000000800003c982e71ebe111db4de1912595bfb9aa76146b9aed2045f1b5b0ed87fec92192dce493cdc4e0613908b347d180bf6312430fdda38ff603d3a16d6e1ffa0267e7ca7ac43806e3e317a4710f1a363f653fa961c566d4dea804adba45c327ac8bf0f1b240c9c02e806f0e8a20eda6f3ef75cb0caecdb3cfc968a531eb423cfc72fd9010001 \\xdaf2d3f185f23f3ebbe4024b9acb175273d4003bb32d9520f12b8d3e6294087804026529a72b9e3429c4f0bd3b38f23a176de51b9bb97c59cd5f9f435fd0a606 1665559407000000 1666164207000000 1729236207000000 1823844207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-45 \\x66b4170427de16272fdc61cfda2abd6b02318fcbb19111cf72fc73fdc6b27f16289c9ca701bc237c6c38c5da4aa4cfed9c0598b1acfea5ca26c8e644a48ae0e3 1 0 \\x000000010000000000800003c2df7d3f92037690881fdb466f7c784aec577b98dce9c57489ab00323727b6590a186f41830bb38377503c42275fb4df8e2f358ef9a8607eef4b22f1d30ad20c54a424a190a5273d30631b0054ab97be4d1f0d257f533d25732d50c85b0b26a9a72db1b94eb55758203b8b02812b6dce042d893b3990862940917151cef0c2f1010001 \\xf3f0fb1d02b032f33d3099af4b22a9eaf4b6361fdd13fd956f285a20bd45357c4478afae8ec9badf216f923686f98ecca2a6939b07a60a704fd45b51c9d45607 1644401907000000 1645006707000000 1708078707000000 1802686707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-46 \\x69d437490c9eefa8e84074bcd4c28af62a3c88e5661f05bf105c0831e358fcbec0ba1a5286140b774b62e110c977ea1b79bdff772ae15c006b2ab69add7ea641 1 0 \\x000000010000000000800003e00e1f567a7d515539574b5dd3c24a2b500ec4aaddd9e9cdcfd9b47529d5c0bcf7096b0b5e69af0759e13c9ab9048652016c05bee54d6f317fca35d67988d7370bb92ef3d43d032386bbb8354e9f8fa870cef00abe4015f215fb75d4bcf6e0d924ccdd6ba92f0839467e3e45ade7b94e7e8da71c77a9a35423a20775737d4fed010001 \\x4ec130e57dfca647dac65e076f3f2b6923c474c44c2efdb78baf5cdc4b059841bd3c765bb56d84aae55509a3e27c1228555647697a123b5df5693c471d98440c 1669790907000000 1670395707000000 1733467707000000 1828075707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-47 \\x6a00bd5c69a7efce4aae1ad541a84e57acefd65832be417dca496e2e008c89d7ca439e56a94767dac14fc4464d13f988df4e03722ee7166643b5990c8128e1d5 1 0 \\x000000010000000000800003b20ddf8a9f42eb0e54bd6bde57c793fd98ccb65501049294ceab0f73788a98f8c27ccf1d5973319a8b7171cd237e28d553bc426c9ec648b6f523f8778fa71a1480009412ca3c9df4ede46e75741da42870cf018a482db1106e53f90b210143970e48400d4338cad9b00175c5254074f90d5988fe00f7089a6a1a93ef1a79ab19010001 \\x78bbc0a1823b57d4a5832da57ec4c075c54e6768b8c93e213f2664cd42c6e1937b0dbf2aad67191c7a723d4914faf9d8703c031cd5795b7e3ec0671e1297f20b 1641983907000000 1642588707000000 1705660707000000 1800268707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-48 \\x6a34262938beaaa738f26be5702dabee52788a6f86512ef3268b6db0277023a2cf8ca5b4d1816538f07a629d4aed6a5bef9b2ce5931b4c09f49b817cd59d5b01 1 0 \\x000000010000000000800003c7ac508dedbc74038a2537cccc381ea249fabd967edf597569be049bc95095fdcc368ae6c2e43819f9517755ec3fe8a7186a5c0a50e049cdb2058ea7274f6ee2ef5f8c71d550341a1d499905f682f4daaf2c23267199f654d4ca47961c3db049a0a40fb1dc9ef6217d99d3451d50ebef8b8c5da4555786b64f86bdba43c19e0d010001 \\x36e94bd301ce5250b8f8daaef52c5428126174cfac290a545104a7edf81b732a26ef7e5baeefdd4b6482ab313e326071c3dbba2ede41d51e29a4bf91f770fc04 1655282907000000 1655887707000000 1718959707000000 1813567707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-49 \\x6bd4cb0acb6db03952b2709ea63364f7d714b5115f071665d735b87502ccf558bf2ac3cb5850499c922ca182206c20fdc3668de99d1ed7fbbad313750bf19267 1 0 \\x000000010000000000800003f13b26b0d6601524d63cb1a2bedd5fae00318b7a7502e7ce8ba32010f3c1c1f4afe9228d2495a975ee2c63dd4b662d641f4f4682559855c12b27e494360a23bc2aebbc7be5968b2e876037d3ff27e945e0177d4485bf1a38af93a966ba4919c7b276815ed987bd51d80f6299a5c08529012e5706a99cab001586e3a6a0cd9731010001 \\x5cb86c174d7c0b38f434cfc10bdfb1854a11d2ab7c6299829571940620e6913eb7149099d937d46701f3fb4a6c51a7dd2e046c1492522ce2a8ad5c995f775807 1665559407000000 1666164207000000 1729236207000000 1823844207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-50 \\x71d095c4a52f9f1e148117cc20682892d8f962b9326cc2c2dd0f653925a2f213fe6b8805889911e6b12a2e039923c9d7215dddb2b114ec8b5951aae3b9242163 1 0 \\x000000010000000000800003b48f252f67e783a22acda50133d2076188fcbed66c86e419cad75d3e37d9bee2cc9199183300a301ca0a266119f1beccbbc47342ff635bf1dd3ce7ba81f8eae49dfb745de2b6e7677d13a5b21099ddaaad7dfa6aae9faaae8088483fbc3e4fcd8a077389fa23baa61813ab142915b4afa24acb20b85a30581780f2e465648469010001 \\x81231e2fc3a329a1a68ac604c99b82eae2da9fc03e2e9097bd5f4944cd8c02205df53a7a0aafb8d4ffb15802672f13091cb3d502c465f9f8ab7c96bbf3099407 1658909907000000 1659514707000000 1722586707000000 1817194707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-51 \\x71346595b726a62b10d89dc3436eed88f64eca47da9549ed7ccaa8af982be78d0562c8d0141cacb5304cf87d387324bb880fce967ef94049d9376cc5e8167f36 1 0 \\x000000010000000000800003d8584ba0bc3aab295f7cd29c8b839a9d4f3256c314ad64871e5936deaaf35ffa3923cfdca62b406c75b2a20d18bc32e490ce6e705fb5ce9faae043cdba62ef29efb8f763e89c3f6ef9b680391118574616dbf860074a094a2e56c64f5d3f11e106e6a047362c0d86fca88e6f163b5c3f019f9697e1687c561f7bf67d1adf1fdb010001 \\xf46f81cd33d76d9638715c20d0e4fc6f6355a1fe0db17d2671327afe8dee888f0a96001c1e60ee6fd58d397c0fbbb49dc7bfe0135bf3b5e6000326818490b108 1639565907000000 1640170707000000 1703242707000000 1797850707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-52 \\x748c65c29d1b1258b94dd44ffba9e9cddf854fdc1a362fd67caa691736c74c21d39c39d3088c76ba379899ddf99ca8c8bc84fb0673c1afe208270abd6cb2bf91 1 0 \\x000000010000000000800003f2f108eb97caf46df17f047a6b8a74e984cabf2c039d828f7268d3c906d746fd911ecc9e763a2147335a2b63591869219fb7bbbbe5f5fb991b02b8396fa0ffe9053cc0398927299e1661bdc26c703f598ccad6f31c641343dc7fb6277db09cbe05cf049fdcca9426e4880498d32cb3d7634741d2ed3208cb6a4efc543ed47fe5010001 \\x3950aa73fdc49541701840c677fffa211a157d3a33fd6e3603c6d052942002c08a598ba710407a108bc16fdbdfd40f679ec97f8fb50eff4311d7a0d3564a0f0c 1661932407000000 1662537207000000 1725609207000000 1820217207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-53 \\x74b00dca32e02bc9fe0961d9efd26bb78b0ddd9a4a23033a01c2cfb1d2009bac18858f7d8efe8701e95d6844d10198fd3648de93ca5f560dc53d5519d76b15ff 1 0 \\x000000010000000000800003cf0daa048886a3c5fd427c54a036a612cf90e95ee87562ced14c385afa56265a20f936bee723504b092aa8b5bd7a3125f35f0c6ac5184f5fda18322c3817b150cac75b03fd92a5e6993ae15002aec550cbd2b7ee13e63f008f02f1239ef76891c5e9eab1584df4635b78d6faf2638e25d4ab3263e2f184bf07d855ebdf4ce051010001 \\x2aafca874a6ff3a51dc452524a756cb8b235ef89baf3e53dccf423f6f2dd1cf009615d7093a720cbf029d4ec3c2e71a8b774c2a82bf8aa030bf18dbf4d9bd907 1643192907000000 1643797707000000 1706869707000000 1801477707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-54 \\x7670c1387d121cdca0c983994f52650aeab558c77b52ca34f74b2ab27b90afbae87f791e8340444900698ee9599205a920609a4123bd0739978a716aa01de511 1 0 \\x0000000100000000008000039305843d1e07dc5eb68d69aab96f0462e1cb87295df6dde1ca13261dff7ab8c2588f3b5626e9b8c6aa1600f77a2c79e89372fdfd1b9e7f2e2aa7ce9dc5add92cde3f179eca52eacd7e6d42e4264cb600c15f6a3e52c81d719de86a2aa70b5069f863d1babf0f6ce9e84cdd95999579b4822149d9752839abd626240afd271b4b010001 \\x5922d28b8ae9d03aa1d62b5df04639fcb89515196e0743b5794fdbc261aabdd9c0a2ac6b78b5b5ed09cf30945d38356771742845381b1958355e76f8d94f0501 1645006407000000 1645611207000000 1708683207000000 1803291207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-55 \\x76e8c4f0441f13c785f0ea7429b481d926fae0d06bb644fea78a1a92d0dd97beb438e66c8205e32dd30f8a1347241ea2153e51b6cb1cfa9ac6939b6e17764f43 1 0 \\x000000010000000000800003b36a05d1080015a4e0104eb18ee1e572936d46695218781d28709be85801241f3aad0cebd16bfd51a20917d1e017ba2e34a2033eb160950be5c5120f501cd1a535173eeae937b9c6c80c2fd761dc7745a9a5b96c9c2287e585f8d569bfc58ea9cfaab6d071af3e340e18eb4622ef514ff7f2a0769c384174ca19ceb28a62a61d010001 \\x78496816410a61ada88cac6a1c16591abe6881d93d27b00655db7ac9412e186b8e7a8a93c4e9c9e0a60cbea73f2d1463df7d7443210bea59f5b226b33cef1b08 1665559407000000 1666164207000000 1729236207000000 1823844207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-56 \\x78b41c2347a620e97040bdfe45a0f6b3ebf222b9e485dc880468679d7f172c8490e54389fd96c69605d16c7fd18b4140f7cb5f5450611bacbbd2f1187aceb8e7 1 0 \\x000000010000000000800003ba22bfac159267d3f7bad306d3f4bdb447c06ed310c30068102680a105bf290fcff03985267c5b7794bbaee52ef39a09cc404f02f6cc9eec15f7babe3aa98981ea3bea1c3a3c4704a2d905bfab4d052301f0dc72a53fd8699f90da6ad63b6a93a44f3b8e4d6ea5708daff9da6a4e0760fcba81bf60060ce1285ec05d0d48bba3010001 \\x67d8108f75f7262082db3da3e5893f2fdd0ec3488f78ec0dadc10d9be9c3234dcccceb8ffff621955de29824b3b5e4fa8e150cb34bd97de40cedc2d33ba30d09 1654073907000000 1654678707000000 1717750707000000 1812358707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-57 \\x7920681d220de67765ce401b6aaca24edcee13af9b7f7304c219ab2ce93e82437b7194ffdb15a2473f65e5b52c3cbeace9d29391d945a0e2506ecc971ff5563d 1 0 \\x000000010000000000800003b03dbb57b966cdf478cfd278c2c5a3b921dd7fc0baa7112b19a1968272fe72092f049036110b637fe7a0bee93a5f13851356dc08d1b238bdad468b624eb1b2164110c5daa3a5e9c09757a50d5d85923c821c9bbca1c7c70098e61bc624cf8e6084ee2a36bbe7ab45eff3e8cf1655be631155bce5b795d0eb7f9e32c33b10d3ed010001 \\xa4067152385013a8c1bb4638c320d741f8958f9771446595d922421ed3516575bd41de5f681b258946914ba15351f7f2899ba2be6e2a92dbf3a33bfcd929e70b 1648028907000000 1648633707000000 1711705707000000 1806313707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-58 \\x79bc0514fa18a75e0b63afd189cc1c1c9aa8574f9dee22b6984941e00a62b1e1ade73bc387483f16093a3ba5ae7e2a6e1c5e5aa1a4385a5754bb35d76200033a 1 0 \\x000000010000000000800003c95a852ee230873f4edf5b2093adf580ecbde1d1331a8e7bf46541ba4141f4b878d6575e8b3854b3270602d541de920e6538813f32060dabdcf3f28ad48a50d62976e8b6affae4c2b1c69fbdd258c7a6941e2bb6ee8cc87a2dc9ee5e334424ace9042b3750a6b41e61ed3e4d5e4c0bc6396906b8a01199ef173fbe4c33e7c13d010001 \\xe126e1ba45a252ffdd533bb76a91e87fb16cace102285d550a9d620f85792457c1c62cba391fb0f9299aa4a085a7baadedd68dfc1411f4f41de8cb254a4a9708 1662536907000000 1663141707000000 1726213707000000 1820821707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-59 \\x7a6435aaa6e144de146351add9a8afdccb3abdf17935a08940e252dbe4b0cfdeb4a4a61bfa20abebe38ad00b560818127a78eeda28e08d1d7588cd32a1a66643 1 0 \\x000000010000000000800003f6299a8d54a0b6864a4830057a44ea32cbdf3b1e54d4dcf17e425c14de41d6fd3a4ec25e4897a1024e6869437067993f85857dd5a666d105b2ef866cec1bee67e7de0324597a7853b28fb0470cb5dd3978b13fb7215d37684f88f878dd0c89d9c5e8e8a00f49e47eef560e4ba1a647fd172b26fe7abd1cc0d6ad144bd45861cd010001 \\xbb18fd96a3d94946986a83a19d705fa85dbc10eceeb3f0a7dbfd39782c740cc980d5aef1ec974e9952dcaf35215d1cc619f42da99398c516143eeacea4d42708 1652864907000000 1653469707000000 1716541707000000 1811149707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-60 \\x7ca840231d9b8b3a79430e6cf4c18852a551f7af0b715db106aefb1024bbf1a2f52b0a2c55472574f30a6aac2fce4052d0d7782ebaa7cea43563c6dab54a24b2 1 0 \\x000000010000000000800003c06ee06b2c2cc562ef7589241b49952e4fe75862686627cf28da38812184b2381e60dc69c3c73669b69c031f9e6ebdcbc2b21319fd806cf1d0d03ce732eff5c20df4e2ca0123c64565ccb0e4389b14e64f63023fd482dc5eeadc77c0012a152d17c81c5626cc521b0085126ab82243e0ef7c5062fb108d55cc7f7594fec8e7a1010001 \\x7ad6f052dcc9c6f9ade92361b35a68acf7c63c689b19f80fab574886034b55a883ac80bb38f055c942afae6b968cdd5dfeb7c849f320911e9c8b99316b6df20f 1663745907000000 1664350707000000 1727422707000000 1822030707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-61 \\x835cf62da2ae3d296ae00ceedb1998c73d09a0f95cb38e4f88fe8fed4f69a293d9f7f719a72033bcf7ca8ee09efe0b83902e49d0a6ba68869552def183c05897 1 0 \\x000000010000000000800003cdcc6085823a2554cee19179db82958d8baba018cc9595b356d22d1cbd4733b1ec51ed0e4c15fa952ce5e9adaf7d7b2ad2b990418264e4d03180fdf6aaa71f1c0e8c42e19fd544d3d0799f4b69eb07844586095266ff7c9b17f049892536db4a28523a5832afbcbb77a065b413f1a5953f946237b2d58caeb819cb5c790ea597010001 \\x66f4f3fa72a2597b1972380e40db0c969cc2acc8bc071980a1ed8f8eb1aa875bfe9b50c88f6ea037535acd5ab383ace162bd9a34290f4b04a8e358350e2e980a 1657700907000000 1658305707000000 1721377707000000 1815985707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-62 \\x833c224b510c3751dc32c1ea8afc41daa86ec09f65b6d7b7b409a1ece04e8795aefc67b6aa890a47e3599585912f86a80fec3876855de180e4734d5b2d561b78 1 0 \\x000000010000000000800003b157d3c02f098231ca75ddc0f0e0033d2d442b9e0ebcaecf3c2c88f8cc04d957f1591f153830787b8dfbbb4c1b3c05c1f7b87d210f67a198a32edaa0b34aa8d0fa2aea0d6a624c1f72f8bb8be77c12a9e8f1e88f722683eba8b4a1a7e16feae398ebda3f10adb949806705a4b2ed7dcde70fdbed222482e83c02364677a0f07d010001 \\xd63f39e77df1144f0d5ddf9f47185eb3e07b89d9d1b98faccaecc2763bb8d44cbfeee813505134fe29c5b60fbe68692d1935ada8ec524562c1d1e3479dfc0701 1643192907000000 1643797707000000 1706869707000000 1801477707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-63 \\x849864f251cccf947fc3eb1519fc90af18d85890fa357d718858bea4998a9bb6cac7d28d01a137fc7ba94e76034480b12675b8e637dc4725863a1294fb4dcd42 1 0 \\x000000010000000000800003d341e0e096a97de98cb19ee57d985aa55f7ff3ef55336efd70e14501056cb852d27d20095406944d4cf94ba4c4c2215ab3fee0fe2c39363bf0b5bf98143aa5154d74dcc0118a5f19efdee018353228bea35bc39aabd73e87d7cda19758d91a6fa129c120a208ce8e71e90e56516c279edfb3418bd6580b06bcd928f6aae514d3010001 \\x0a0f12dec446fe32821302caa28b293245f6ae68f7a5c020390a810972d09d571a74544428c08ec8eb6d216cff483ef961b121716e690a763eb930ad7593d701 1657096407000000 1657701207000000 1720773207000000 1815381207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-64 \\x86e4d14d122f18742644ec85a111f5e480ffc9d2e583419821f52a89816b2f8fc889a2f9067d0d004befe4508ec600867b18d82349a368f297c179aa4cd0d85d 1 0 \\x000000010000000000800003d0788c4b45f06e032f858f90e7cb6a65996a93cccd009d5e9eafb90b9d70f3669f735285aed1c2c33b954510fd7fa818ddffbed265bbb3bfba52fc5f98a93f5b8a782555a970034a5bf8bfd170a250c0576a17cdd6c97e7e5867ce3ada8e37929ba8abc14d7cf6e166b6d538efc3fe40daa28bd6e0a58a158aefb51aea57964d010001 \\x04da9211332f37774a4c0df3f89aba72fd05c03a63a7ff92e8bfec8a4ee0aa919be3ea170a59b018964d067c79b6adef31e5a3b222314146020a77d4b4c87205 1646215407000000 1646820207000000 1709892207000000 1804500207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-65 \\x866493637036d2c51d8d1132d70d24f9fc44805af9ab5fff2ea559a2fffbf5516d0a13701adacd6399addb4bd8c2e52543920c7700651f8d5f85e9641a98b690 1 0 \\x000000010000000000800003bd61183bed377a2339d3dff3908167e550a1594a26ca4080188f60b507a0729e7fa6b5583f84d7f1301fe49d069310293dc625557c168b1bbbd0dea655eef038ed7b57c5786c9cc245a7f270aed05ae41ce34e46a9bd4eb0c458078df65f8f763e1fa656418f04c25344ae49cc9a14994e2399821788a2c1fb017d72508059ab010001 \\x4ecdb07a684e2a0e87981ddfd5122f5e8da898f485ce90c08ab44f051bafab27235894873b90b9447fd21c7d7b49d92aa567dd0b175d0c2136d011b031540b0d 1642588407000000 1643193207000000 1706265207000000 1800873207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-66 \\x8768627e8ac99c2c0973af737d9f56234c2d66eeda5c919846df02738a89314673580d18befb3c3b719de5203c0c41bb767da3b0b3516c0575fcaa49059b0335 1 0 \\x000000010000000000800003aa1281b825eaadd71cfd6f0a5eb96caad4b25e6d19af482295c5d15c89e8aee22253221c70e88b23261e816b3d7cad3136210d308ffef4a092d92a2e112c6e6c93e872faf50968680ae980f09bb2a76d276059e01ea25fef1625ee08de1b80496c46f0e586525f53d1386c69c3e0ca3d43dd303c5c6d8d9da7e92be3a661c23f010001 \\x92b8c0cf081d4e2ce8dd3274a550a24c16e96d24140bcdc40b9fdbe90a76d4820d2ed195ea5eb8f21a7c29c56d5496f64a75d923aa90ebec42aed0750f32f703 1666768407000000 1667373207000000 1730445207000000 1825053207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-67 \\x890cfc94ec3ea98af1e67d6458d9909fc7f4b836ed351ebb293144c4f62fdfd3f5999cb207d85ab6b70447ef01ff7b671c34f8e47ad0f3e26e4ba825a229b47b 1 0 \\x000000010000000000800003a167614df21a6f121062f62431ca89259745d4147b2c6cde459922f08d48fccbd5253996052f9d2a1428488fb052e29ce2e6180f42215c8866005b3eb9fcf7cf5f0b0ff3c70ccc3ad8963ed34d8c27a7b553681e9bf7bd22845f945211f7a69dfb2e12d9c7e1ffbb8b437b54e721e0f65e29d9abf4f07b052f7db660eba78c83010001 \\x259efdffd90f57b2b3635a23d3633f591e90e007ebcd0331f0f7aee510a86ac58037f74fa0c30a76baf2abe299a2309ddd549116c74b9537595a3d9a90e14508 1647424407000000 1648029207000000 1711101207000000 1805709207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-68 \\x8e3cbc14b02186cb82a5b63c4a00311c978b754217881a16c984cf9c12f47d5dc5463b95396335d0a580c03fb213bb9591208ee4528bb1043760ef9e605f9b8c 1 0 \\x000000010000000000800003d7e5e31554382453e69c6ed9c21abb79ffe22d0b1795bbc17edee32c1b3aaf8cbbd275eb58272ab2a788684c0b79c17883e4f66e3f7cedd7c639f722d926ff8b3c9c7918c77110fd0c72644b761dae7e2e334f72e63a375c67e2d3a0617211577d1fadff6c5f4258f8e270cd91376f2587fa71ccd7b58af7118e16bfab13e925010001 \\x600fda08915faa837e4c060beabfe3547d308f516c9a98851de729681a56f1e441efff225081114f054f564fe2bd1d8abccdfc2a02f036a33c88550fe1cbf20f 1667977407000000 1668582207000000 1731654207000000 1826262207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-69 \\x8fbc94403b7006a569d29300383e5d8340c045acfd5911b7ac6616908e745855ce2afa1bfda16f1a7985dc5fabd35de079e65cc55a8c421225dfeb942c49a8f1 1 0 \\x000000010000000000800003cc71636781572d3625fdce1a68ed2718be73fed2b52df72d627dbe1a2f719a79c6ada5c448535dafcdf2bcddabdb0be8694b9bce76cb4ec832d3b38c106ba90ac2e7757137bf1303bbc9196643782c719644cca9c7baf9882f733e9fdf121fc61b42217948385b409af9c80b6a5e589818b5b8da3ca55e9404a98ab6b283a451010001 \\x982803ba2b63c408c4a536051131ba5671e53224d2da5f62dc7c9d6f035232213bcd193c47450317ef2a2815646e0c088cd6f76aef4aca158b72b4807fea6a08 1665559407000000 1666164207000000 1729236207000000 1823844207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-70 \\x9224aec00d941ed75687b970313b4f33861d293796ccd682b10555c940b33f72a04ac6fa7e2f943b39398d4698cbe1a029a9dca446e1ef6ceea5f76717b680a1 1 0 \\x000000010000000000800003d4564d8a9125ce998a5b13e829e857aa9bde5c889fe03bdd5986398080dea64d2a091cbea155da64f860e3b804d00e8494a4efe031befd6cc9ae3f512e96da2a2885e3e35572e2aab7937502a37a04d8f831fdeaa14c1f7d8ce94f99a7ffb1575d1a26c5499a2571c3a289f8613c2a55e0777c6697051e0946d6c6b6c0aef6b5010001 \\x115a8974747a77e03def0d6c65c763e21208a21ed50fe4ba4241181720225590bdd7447bba9374070c912befc8fb800c978e594d34772d08dd274c3a3ff73501 1666163907000000 1666768707000000 1729840707000000 1824448707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-71 \\x9488b7b495ccce71d2ad451cee889c78aba188aec463b8d96ea6d6310311ec91ba1c5caf8a38248029fb160f0117df3666c0c8516478774c747f6c880f1e219f 1 0 \\x000000010000000000800003d61b37ed55d51036bb277684117589fb885aa8b4c508313c4f7bab6308e1f9194fbea7217ca8fc30440c8091505e38f07684d45356804f563c491b2ed4ab977c7e6e60fdd216b24c469fad49485a47e4a822b16c0d40f16b6109ab927f1765399a21a9f38deeef69aba43935ed51b73ad99f11a1dd42ee28e92efea76ff0bd21010001 \\xd3fd40cdf3954d0ae3171cea5081245740c5f44f0f700df1e178b747e8f6743089201fbbf32697a44ceeb1f8494acc235e991844f0729924755aecf75cff4403 1654073907000000 1654678707000000 1717750707000000 1812358707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-72 \\x95b0ee54853845c3c6e92c66da4ad6cf1ef797d719a3de8f719d5e4e03cb53b3ec7c8d9aa5ad2c1c05dac022c02a52aef3770f8012b9dd9338f3d1db2d566f85 1 0 \\x000000010000000000800003d1500c5ba1a47e40b752fb3d5b91befcd7eb8c7a38a1967227d563b9c9b2b8fed7952c969615c8b4e42a78c5ac89eab0458ebb3552652cea25dd3e8c8ab663d88a7b82f0c7f22344ee0766791393c9907a70476fd372b4517304dcd1cc885a07e73ff4852014a92c892d5b9a66dd217ea136a943c85b1a28834921fcbbd4e0ad010001 \\x74ae5d015794c947d83ea95837c0c8e13c3f9560d7c240a00c01dfd6356c05e9bfc200c2e8e3af061cd7997adc8af198b63c3465dfa0f534d884a7655aa3c902 1638961407000000 1639566207000000 1702638207000000 1797246207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-73 \\x9584e8f117423c2f97cbaa68c13918969187913ea666c63a2ca0cb207d5524bc608e9adc436bb6862c63c6f01d929645d9227c8b88b8954bbb002152993206a7 1 0 \\x000000010000000000800003eb5197761d7ba0812e9a7286d6fe1d2bb7db0a10cc144a842c135a71f56fe245274502954f6a43a97bb35968f32f394bac31c39e1740c52bd3f6bf05a523805a0c7176c65b1164bebd641544b6e201513317015a21b552b379ad507f6dc53f807a615bdeaf643d85664dd09430a1c419dbbd946c9c762bb2098c8dcf2a322ad5010001 \\xd0cdd9491ec861028d8942f67daba4a1a75558eb76b26d9f252fe24327fabc065cba1b9bb634ba50e1cd4d5f485db3296922914ea26e96cbaa581043a1ac500a 1646215407000000 1646820207000000 1709892207000000 1804500207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-74 \\x98ac7a696cafa00500ee00f22d10243081460b283a69823e328e49ede0c7daa01f0c19cccdd6ba86f3c2e934147b1f373755038442872b4d0714563b95b0a524 1 0 \\x000000010000000000800003c582e0e2c82269fa3857134b9fd24d1e4f44eb0e302c3b1eaadb630c67911eb5abf9eaacee3eb1f019577262ec7e2fbecf63fe1183c97f6d46981d3f136eec82697604bea9bbebc741e063bbe8bee008d13ff7be461edbef93de7ce8616f8ce4ffb8088799c336871087e928daff5d57d3013e9f731d225979160fab87c4d385010001 \\x3984c31c0eb74bae221236e47ee5971e3423ddaa9b1d22ee516101c61c04012bf2fa0b54923054bb5903a5b2f7ce973c17cbd2463b9ecddafad7051974de2b09 1651655907000000 1652260707000000 1715332707000000 1809940707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-75 \\x9a80c2c0873e2e12baf1945948876e75b0d826b17d08ae06d9cec3cee0706c6d9b36c36f812a22433da4f1370131028b8212d25fe169bf75f5101c07a60b9a3b 1 0 \\x000000010000000000800003c69a1ae2cc601c9a94c0c839f5b32ba8b0bc77c3b3b908b6f27c219169a1803c0e23a36de6824afc5cff75dbfc35a8f201f1f7c6af21315e84e377782a59adec6968bdbed220c6437cdf76f67e74bb87dfdcd5e8d0e1cd5c4cec1860a6db3ef5d38f02b108a9e27f7b66992b5a96b7d3ba9390090a2aacf3fe656cd9403f22af010001 \\xbc1ef06ff56e5ef471f411be6d8c93ae43dbe0a7a5f0b06cec4f1e59d66c45f93dde60595d40be13d7e6d1804fb0a63a49fd1f7cf5e5f40c4f0f73f715526808 1653469407000000 1654074207000000 1717146207000000 1811754207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-76 \\x9cc8afb2f9b5a78017fa89f10c069457893a3a301b94d1e5281ba0d08b95a3e67b76ea2f3aaa23be8945ece91ce0ae5008202487a5ba164d6b009de4ee40bc1c 1 0 \\x000000010000000000800003d56eb35bd6be96bf148cde4412a4fd6647dbcc8f441c5c689274021a1ceaebf178ad01aa8302b2f63e5f646519acab406666ac35f62a805cd7bbe98be2a39f232cf7efe895f7d3e57b1f3b9b7f57a48029f01fa5d2b3fa2c83cb812a96a3719fc6fc241a1e3aed0109c475ec75bf6f5be53d432422a881230ca03b814dee3c61010001 \\xd49c7374a39c3ea128e5239b50f621e1b5fe00c58b3b41945377e92e11e770d949b738d1b9a5b7ef60aa038c338dc9f4161553ce6b8fc385c521ec6fac62eb0e 1658909907000000 1659514707000000 1722586707000000 1817194707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-77 \\x9e44b8f23d90e58669418789abb37676c0d9642e0c3e0685e3d0b5ec7619246cee4f380cd5e225a68b995802dab3f7125100d0260ccefbed932d1bd112f74f15 1 0 \\x000000010000000000800003d8944e06d5bc6e9cb6a7f947f0b2ff7820856582dec62e01709a41184179859bde8a66b54a8395dd068c465e8b7cef5a3bf3cf64822f046611046af84f26f0e8897aab8d7d49008d542dd0c5194a4b13698db49dfc585ff9d1909154d95da893289f754fedad0bb35789a9931daebcff4933daafc233e44bf06ab43f57a1d2c5010001 \\x7fbfd6c80c33105f591a73bd64c3da344755ed6321986e737d7d24c8a60fc189888e17d5774c4b20c04bd0905739763431677f51e3fa57d776858e5473c26401 1665559407000000 1666164207000000 1729236207000000 1823844207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-78 \\x9eb4daaa65acf1d91321b99236ac53dba73bfaa4673ec518f9c29b0d3048f96c5e39eaa1861edcc63c7a205eb2d90f979e5bc9ca1216ea32d8888af8b2f94f33 1 0 \\x000000010000000000800003c52624d7eb4f5f7eca6334d7052e0a2c602f157ffbd4ae809d993e6d7ce7e7c45025cebf2bc21cfce1447edc97e6258b94b90e093743d54fb4afd831d084462baa58c811f35474f35ae86701fa550ad67f59ec6e543055833ccfcdfc024b393d46f87d18a2b059275b47c651e145df86748fe04d294d475484ec5a0ce8bccf3f010001 \\x2f47a1d45ad88a22d84cb416dc89fd1a93239e5a57afd061b74b831851fa497b89cbc6037c90e66e04c1a09e60e785f8619c995997eada1bd1e8fd28d2608a06 1657700907000000 1658305707000000 1721377707000000 1815985707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-79 \\x9fe80dddafcbb04562031f8f0536414c8ab4ea000a76d0b62f34b93f3c4441985b51273f9661c968df1016480ecc1f33a5aa2df9837b86bb9c20980176e135d1 1 0 \\x000000010000000000800003b48d5e8e025aca7a55181daabc7e87d18cb47348c176d27189d5fc2bc2bff823b44300db7dda01a9634498abff771bb8da6233c16c3eefb9895dcafdbdba663638ef13de2f1e8dc2232cdb203f57a7e4287faefecdeffcd3f8ce5a920daa31e36e059ca874c060c7576e134f366d9093cfee41058ee80d1d52832470c520026b010001 \\x7b32bb1031c099adb52cf042fb9de49ce4bebfa00c13f010d96f4c6200101e8174fdcc62ae717ac5e082c2afa60171d985f5065ff10ffaa411135b9a04bcee0e 1652260407000000 1652865207000000 1715937207000000 1810545207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-80 \\x9f8c9e5d1d0a7900875ce5820461be6168d6b6d949c9a23a762ef6045e2961db53383ee4bfcf58351695d63fa3c67f1501a0f151d085bc2770b6a048eb7cd40a 1 0 \\x000000010000000000800003d1026c1341ba31ea966ee83305fc829a5e6e265f8099e3742a40f11fecc83cf167150b06966df6e23693a9ace1ee1c0cd2dfc0c6023b89fb92babf11580f8f21a4ca1ecef547f10ef75c3296ae4f288dbdef005a24801668e2ff3e661cb8437c27d9e2379f0ae91c59618da03f07180c3794bee3a0858654143fb767d7d30a45010001 \\x493060634f96cfe583ab668f8da57ce759a9070760a779f0939f144fa15859bcf68e40affc7b5a2fd4a130ab3a248bf2816d320d23f5bd4b6324d2868836a80d 1669186407000000 1669791207000000 1732863207000000 1827471207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-81 \\xa058d5d0fd8dcb19dcf309cc1180313a36dcee21337bf4d0e1d6d3b352da228017c35e454da1b7bdd085da48b4b38dededdc08125189182de9f8380edb2a0308 1 0 \\x000000010000000000800003afd625285a320a7e93aebe1702b3292983de1cbabbe43194558d0da3552d2c257f7a9af13eb42ea3f08bd2c6aaa4e06bca39f8f6680cd0da31da9c3cd116089ab580b676fb3a44bbaa3180e68ad5515b75d490f17f55f1738f332c0820fbdad59e086ebad815444d9c1788333d2c4306d67a7ac8542dee3c5c603ade09e53c5d010001 \\xaa8ef0ed431c6a026979c26e6bc00e8723ac36fb52ba1ba548e8b70983e7904ba5737987ff5b0fe990326e81f287fab4e47c3d03d42db14ed2567108e968920c 1660723407000000 1661328207000000 1724400207000000 1819008207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-82 \\xa000a4c20b8414d9c6563108ac9d9c4cc3fb32945414ca3588bc955ca48d5fe6d518aa67db79d5d3d9e888a0288d5c9ccf125e7a5fe4a0d9936944532c2e21f0 1 0 \\x000000010000000000800003be29c7381a66b3318557302471b648b90d7191f555f1ebab2a113fe560a5d5bbbd5cd49d069e23007940a9e00f2878cc3722b9ac4cdc18124185f867725dd41d89e683b42e7edac8eae641377a151b9c1cf6965191b9518e647294cfd16488b55599efa1d71c7b0a34e15d144e6c015c36eadcf95f54fc93eedd051cadb00d83010001 \\xa05b997c66c5085c48f3888753780189a7b00781799bb0aed8a23415731f32d664a754a8a8b5078193076f0db00ecae866d1581502b00dfae2e2ef258044030f 1640774907000000 1641379707000000 1704451707000000 1799059707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-83 \\xa274ea8848e7251f61a2b806ffa98c47ca37e3d2aed8eb739dcd693a55cb70a62c0acacd18aaea347bc14506864aa1a2fc4c2de34faa8a439d44e26e1dd54fd6 1 0 \\x000000010000000000800003abea1c7b0aac9dcfbe75ab32dc4f573c29a5365b303e7bed9418ef2934bffa9f77109e93ff4a981a7f1b385a8aa2591cfbbd27bcf83b008f634877bb4228370988a1a4c524c196cd56cae924ca54d3e61223fc9ae48e29adfe9afa693ddc951fee210489fd3f696f0ade5ea5a07e153a79d9b3c783c2591c2d1a9cf6becd0e37010001 \\xe5224ce4b9c3e390d616ada87de6b78a400cb3df813e39260144aaf0fdb19325a7c26c7d32e0e15523c206f86051b1b380b338e504b559ada9b8666d49439206 1639565907000000 1640170707000000 1703242707000000 1797850707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-84 \\xa424d4e23dcde17d78d8aba886252f4219d173b88975f7957cef32c8e4a0a53dd7973cc32e2e95d03774f400478599ae8c031abd09ca0e986d6f6d23f6b09153 1 0 \\x0000000100000000008000039d2dcd7ec0b91398ac731bf4f3b9028e9c0614547b2d46f72555a0bf4df1a64ca91a2962af56cca0e544707da344aae148e49d09879a7a229d5c1d6b7dde31415ea3d23b21baf840f00b8642a25469b40059fe0e316a1ac929394ef38bc3863b88df577733956316bf70dae7e02e79d7061f45161465514cdab44339ceacbf07010001 \\x6768ce53bea2b1a29a080a94b3054c2fabe6801e0be43f8575c10ee64ba53075ffaf54c2e22dda7936e798458dc63da1e2b147880c5cb6dfab0ac5f4564c9505 1648633407000000 1649238207000000 1712310207000000 1806918207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-85 \\xa9043c4c0fa2dd81981004ece85b94dc08576cd1e1a440252c03cd635541fd467dc149069012cce1a80e2843fbe9e4aa357e8782a57a2bb9d1fb1074741d32cf 1 0 \\x000000010000000000800003abbe2b200cdf5f6ee10d89dfd6a7a88f67445ee51268c72b09b4f01d291ed911f3161a987cd65b82ab9dd59c4a75b9b30dad8f52295b904834f9599e619d48d8e4fdf7bf8470145470e695194d52a970ad4174c1c6eefc6d767aaba39ce4e78315be005499baa7dac787a4cc7e185cc36880e11db3158fc50e2fd7164d86bec9010001 \\x5dd45ccab4f518c2802ac254ab49d0c8c2fd61110bd27c4bbea842731737e518a98748e0a9dceda8f3cf689438eb9d1a6387149acf423e1f8070d6a43739850a 1664350407000000 1664955207000000 1728027207000000 1822635207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-86 \\xa91c95477bd7536ec61fdfa3651b7ecb75b2a3d54d8d28fa12539e3ae0cc14ed928cf574144df720d1f55dd7bdbba3c6c53576a88c9f169c9e2d47ac6c1fea5d 1 0 \\x000000010000000000800003b4598b5618bbc006db89871855fef23aa912a4c3afc0c080b5fed805967f7dc029fa82959b2dbe6ed580eefd712fc2ca3e91bee85ef0493f2424cec0fc555e162b9d0a17b7bcddff172fbaede84cbe8f70c46383d7b63e26eafcb544b7d7fbcaae26a3cb6a581134bf31c8f04669cfd5a1040c2697e6827d118762cfebf9462d010001 \\x37b3ce7bc5fc39de6e14f24ab5980dcb72b0533f36383ea18cd89bd11131b3db7b047407d2313414473fd7037188ce6b84ba96bee577f2bcf7cc702c155b440a 1656491907000000 1657096707000000 1720168707000000 1814776707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-87 \\xab248b8dc5f72b96d9624aebb0d10172ffb66bc261cf9e3f522ffc9531fa681d02ac073ab0c467c844306f1157799e6b827343560cee153ac01a6f0d95d4f9ca 1 0 \\x000000010000000000800003acc788a808153aa80972470dc1e3ff35af67005338cbf97e0cfe005dee4af3e4d2a23c660d01fb4b310f442a8a9cf18b2a9a21ea9e758825182ed3d882f07e7d62cae0a6ed6efe002520aed6ffeb5e1b978544ab3154e79d67dbfb8d6721f65be89c7f778e375079a70cecd84eed83c0af20cf98518d0243c9ae24b233f66be5010001 \\xd9cd3f0647bc286a1791f701eb28c55c2110b24aad226e950b9e8be793f03ff5e7050b8d188e57b05c8cbddfc892d35f3742b26e9806bd45dd66945f6a35ce0b 1648633407000000 1649238207000000 1712310207000000 1806918207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-88 \\xaeacbdf6353969c1e66369e4d30e256c628346a7c4b2694c42dee7e92061dded8d6588b361ca5e259a43fb893020f7f0c43fbbacc68aa0e115c3ea10cfaacedd 1 0 \\x000000010000000000800003c5b17e7533658a5819861d77623d6118b1d46943458268d9db458d5976f4133fec053b7f018d98d7cece2dd9460754887d2a8a6c26d87a71d28054ebb27c705d96034dec9293471c00270b78c44cab35d4653299b659bda5cf0882d058f8eae1c087bd6f7a795053e9fa669b55a429aa77380abcaa852015b416930e35b447d1010001 \\xba1fd0c1c26195f7080774ec03778e8955551803f56c8259d1f24bdc26bf99b9e5491312d716890b88096bff6001e35a22b7c59775d5498edf07249fc1718a07 1665559407000000 1666164207000000 1729236207000000 1823844207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-89 \\xafd0cb9c7c127a9c67fb3602ac9f6301517668cece49d9e085869894597ac0253241d0bee3d0bf4ca94e6fd78cd927ff840fccb8606be253cf3ea5a0d6738c24 1 0 \\x000000010000000000800003a6fbf8d8679456408e7a34983798a3e841077a429aa0e058f4c70c175ff35d2bab6a60d5d0cccaa8c28d3459102f570ff6a8726ce1c084c242d8f2e7e4acbeedf97b8774f4bd71ef0fa2c7ee06dbc14fd3ab7da37b349f1ce32060eb9f6eb3ba1cd300e28b3c2025f811a856f62d6380e632baec55cdf4ec4b21d72c5bde0289010001 \\xb8191933adb74c5a657dce08d76ce1fa03724b4f6577f5d3f8a94b242d446099778f11367adf0354bf6c4083d6146c6da1eb37fc492f8ca7cd6a19de24aaaf00 1648633407000000 1649238207000000 1712310207000000 1806918207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-90 \\xb2c86011b894dc18e26e7aaf34d180da225e41ff878377ff870cb4c39bccc5d75de50cd4b4c2bbfa65ce6c267cec1303ccff4a188289c050e4fcd4302bba2c00 1 0 \\x000000010000000000800003ed6503de5f01a13163987f073cd9efce9177177259c4a8261beda3383bd08860b135f6b06822a25ba6b4b5d4f9af540a869dff1c20e3bc170b400fdde1dcd9a8c0289fef7c691b75e3451f945078a39431f6a410d5477fc520f464bbfd8ae44e5417f295011f2af56307ac52a39ca20a06fae1d8649861f740e1f71164b5cd0f010001 \\x184fbcabaae6aa90f1d130d395f3fbafa27ccc192f18ea6d5f0d3689f884942fadfbd3926f2967e153416c28b9e00d651dfcb980126fb53ffdb44820e67b6100 1655282907000000 1655887707000000 1718959707000000 1813567707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-91 \\xb4401877e6e614157dd0833cd2f0610c0a76c0317254ce3ed898f65de8f795f67cc8ac1aa2f703e0e554a5a97515e6babafe9c7d75d21458309c373dd6e0d0d8 1 0 \\x000000010000000000800003d28a6a41e0fdce29574de023e2377a56aafaed1ca30f98aa58c050f76c474258707c33695faed58cb61e58ff39439d82ab249e7d46a641f65faad131c3bd346edc75056d4be4d39cee02429dd2dbefad22289af499bdedf147c2cdf464191dd348bb5901b42553ce76c76b7e802b82ef4b41ff1f58882ca25bb406732188315d010001 \\xcb016e1faeb6e753eb99e829fe83bdbbfa481d638c5986527bae40ea10815ae512f7782cb31f96ae8985982e4ea72bf6f729299632154ea49258adde93f2a30d 1640170407000000 1640775207000000 1703847207000000 1798455207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-92 \\xb570cec8a19c329398e45c4ae17b059a0d1f04c2bda778038c0f88fdba6e8b458502c99c7f8e0ba98fb71eafecc6359590e5af937a310d6bf41240200bc67733 1 0 \\x000000010000000000800003bc63ccd8a158dc34ca09b612d5a40e27e3ef38a0bd004b84bf8a1a8ec36ad1e9ffdd1d745c465645fa73d74c23e1b29fd2b8f140ad7fe292feb17998ff8fc667d81e37f57dfea93d0d78c0cf192fc56006609c7f94b6b1e7dd8153230230d571fcd7eebb67946688c74395900e275c21a8bc799ba468582a33d84fa5d1c9b3d9010001 \\x24be91707ae1390f27b5a7fc9d525c88bf38cf3b49856a894e9ca4548043e4819abc8db525102db0819512377810b0dfb2bd4ba36985e0a46992d46685b7d609 1660723407000000 1661328207000000 1724400207000000 1819008207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-93 \\xb800400c04ccd788653279a7a47a3b598d55ef1131dd1750deb720a688a28e341543b04ea59a09f45d89ec48671430a833075d01c47a744e848212fe7e594cbe 1 0 \\x000000010000000000800003ab744ffe0ed15329ed8af4ae42b893fc19093f58347cff63f7b279f538433b2d683c324ee56a4b9d7cbe7f1afdd6a90aea5bbc1d0cf490b9a7d1ff1b3365b8eb41767fb2f7519c7fb41d3efba075d281a5a600c0fe3f9229e6d83aa64c9d1625aae2aeb312ab81206cc4159c525752fb98a365e3ccdd7d947249f464d44865a3010001 \\x599e93ee71851ccbabd6e2d989aa6b38576716be190ed82ac89982e2b14279d1ddaf5adc5cb7930ec0c78aa8e9392cf211e740f7aec4edf29befede41ed39906 1658305407000000 1658910207000000 1721982207000000 1816590207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-94 \\xb878f75296a69a512dc938bce3cdd582feb2003d18421581a928b897851827dcc5c6d8d5e75f5e9c298c6c816473bbffc941bc053f668e2c99c9c0373d9fe976 1 0 \\x000000010000000000800003e5bdb41f03655a8bae8174a7371efbe963e791358d8091e91bef9be717045662f73ed6b7c11b47901fbea2db638600c77da6984ce689cc90d4f0c2dcc5ac6609d17a6fedca1ac63b0b624a33b6c1d8d8a032afbea988d76339cf96cdd954d49c739070f7ed111137e28fecfc818e27115dfe4d1086264bf08e7dc820f9a4f3bd010001 \\x5a745ee97c8cb444563849700b4149a165c70697cd6ffed639e575a1f29f5b851e278cb1fac23afad8d7fe7358eecaf89e54027a0f8fb5a67a5e8f771f545c09 1664350407000000 1664955207000000 1728027207000000 1822635207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-95 \\xbbb46b920f873997991d06b93ffb6801403081ac542ea221ff5845ea893bb95a08f39598d6aec6db639c9d6d57f60138dd35cc92e44bee2d36b8dcc1bea92878 1 0 \\x000000010000000000800003b7242f9f9e0d696d8b011f10ff320a65d778ebd9885800c0a7475dd5e0131ee41d4b5ecae13ef197f4ab9c3bbf8b2c2d4176fdaae4565172edf2373f305899e52cdcb8dfb8acf46fbec01a6d08ca72e3b26740635da0ba44ecd43048bc465c29b241042051902b5aaf73ec399a5076a275bfa43468a3fcf460851386d388e30d010001 \\xfa1d9803ebe311233a1ccbebd85fcfaf7e85de605bf39062e8872acbdd7f07a700b310c17ceb9b349c640a966adbc336d23920a23812325b7314a790dd3f3100 1654678407000000 1655283207000000 1718355207000000 1812963207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-96 \\xbcbcb595ae09cf4b7b3ff04a7bf45da8604c9c26ceb0a98aaf4a48d6737fcd065b6d0c268cf4d153de3bac7015c7df4de1961af32ef5a2290284225ebc8722d8 1 0 \\x000000010000000000800003c1a20ffc8037b3e0fb692adb3da9fd7010fac3faefd374e60ae26dc2d412ea4f303b323c2779f143fbfda1b72ee3a9210b2ac24750782cf7bae22008cfb03b329d6dbcf38ab77b64ded43ccc1d29fb2b35de5e7c98b225c86ad4248c49c9f646d5e2ec585a27239ebc388afabc5a12eb76279a4035737bc935d2a27fe0932fbd010001 \\x04eaa4eceb7148c28c7cad9dead8d5491f6f56dba566e3e28a0a7ca70439d994f761062c42c81c61e0140b9784fac976fe7139e98cca424e2e9edee76ae52201 1644401907000000 1645006707000000 1708078707000000 1802686707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-97 \\xc2f8b743e2cefa52c18caa0ca4df13fb9de89c7f583081aca581a588b50fe36d6af3f3823b05dc01138a7244526eab47f57e260c747ce47580d464ebb1cc05e6 1 0 \\x000000010000000000800003c912fb8fc6fa4b04dcd0c3ca4804acfe14334bce57da571a8ef43781e7f59f85770332efaa00659a154dc9dc115ac7d43c1486b43c0d9944de9c0f88f7c05b6e3cde1074659f3af657f5952a0392565f41c123285de8bfbc4d098a2db2c39bf1041e024aa9479fa33a395575e274855f99bdef4b017f22ba7dfdc9902df38aa5010001 \\x7307ce031e6f27cb70c4db204e00fbc1429164cf45fe0e46bb3bfb362158f0a666c903a2bd784fe3571ac5485dac9a4200b41ed94a26fa16b16254ed2c42180b 1640170407000000 1640775207000000 1703847207000000 1798455207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-98 \\xc43cf7cc55cacf73bfa6f6217433d9675133501d6020765318603aa2fa224f6f9d2974d554d80888fe47235eae346def8e74f70d27d1b8ed926155aea0055833 1 0 \\x000000010000000000800003c0f3a11e2afbb20796eaaa3aa49f8249a3987650b2dba8055ca5d996ec5c5c73444ab4db895d2a8912236f716cfa36befb4b3c441afa1c9754d44d8971109fcd38aa2ff267628afb47fcc595f6e683a19013a8e95c6b5a7a2af29d665045f5aa19a53886c4a5b1531532356c35016abd4d26fcd9e687f24e5a58baa386881009010001 \\x9d02b95a2a92eabbcd10c677c08e12cc9dfd1457167a95aef5e6ec473ff8ec4d14b89e042909febe29fd870506ac0357373db977cf220ea4288c34d2eaa6040b 1654678407000000 1655283207000000 1718355207000000 1812963207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-99 \\xc4b873d4a42efedeee6285730702a7f4fb31c726c0d5d3236f56726792f8ed8c79a2bcb4813ac8ccb756991c8659348d185cb8a2243394e5456b5ef850d2eb49 1 0 \\x000000010000000000800003a7e5065b18211144298026cba9ac18b0258cce85551b3251b3006734fd25944b9d212bc9ec68540e76ad9833097d0bf3cf11a5b7e9d6709fdc4245f8252f119bd5d8bfff1240d187a92ce8bffe85d74ad3a197067c61b0f296d7a1c20c01eb956f0ead9df5df05f030d02d74b342788eb42a95295d475a92d15f40c0f594e51d010001 \\x0e0371cdcdd168db937acd59dba9ea01d1b361b61277f011ab231eeab4390051b7c07957738106b9c60c86be0b7f1595f0387822b7a7961591772da074ed0e07 1652260407000000 1652865207000000 1715937207000000 1810545207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-100 \\xc65cf8c8a380404a862256275c551194bf83880d18f1853a8da3bf4fafaf3f9bd96a8461f68ace3eb3a5d8ebfced939a04178cd7bd5a9671b0be9336404e9f93 1 0 \\x000000010000000000800003fc2a8bc577e2ecd5cf23f2e178cf2f9063b110af7267e3f3ee6f30670a0978c1604b769c25f00cd01aa7aa3e09a70e11cbd76fa128ebf9fe38b2e1d3ba4656ca99b20314f2d9f5d6963d6094d73a42e4c4d6f111b3f794875bf8da53dcc962b2ef6d85ad90dc58500580c91cf11a6e13081977ebe9cb4e0a43c7be269c51d9f3010001 \\xfee5727b12ce933c0762ed13690458f51da36dade8bd4a34725aaeba06d0d486ae55262f7b3a63884202286031953d3e6601cea1ca48bf7ebc50294e2be5b103 1667977407000000 1668582207000000 1731654207000000 1826262207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-101 \\xc7fc18da6374d15818bb118ace502bdb38e7fb6a0a2e1dfd236ac7dead9446b348bf72f2c89ef0f450cc7751ace4e7529c6bee0b427ef345a9f27f64a7bee7dd 1 0 \\x000000010000000000800003fcc446e83f4e5873968347b8ac876c4b6091abe98e2e137a64c669ba4cccf7445a1e08f7f920795d3071e1d41447ea171e58e40b36975ed562be8bb594c5bce68f9e1cd5ca70fb47d31521355ebb0d6e7dfe0a933a4145cb5040f4bcee06ed3cfc9cb1dadcbb4635683c3baed66d5bef4007d0e4e9467dc1b7bb17ebacc7b139010001 \\x549e8d8183b416d54cb0c30abb9f774430166ecbb7ebc763750e6166945222ae0cad7ed63bb3bd9b64c06fcb188483f954a118c1f93808c9f097b4e16c7a9e0c 1641379407000000 1641984207000000 1705056207000000 1799664207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-102 \\xca18119b3cd9b2a5e5dac49c958a4c5b75934e36d07be37483fe8a488aae1cc0486d7a7db9ccebd9c67b77993fc7c2f1519dc3ec32001c79dbb9153cc8698742 1 0 \\x000000010000000000800003a0a7b8015f2190904187f5369350954b283485fbdda82cf9558a6703099cb4d3e612d9b34e05bd34ba792d2c05f8cb94a04a7401445c86461feb4c49915e6ee2be6c849efd195917d7e9745453a726ea7d6efbabaf14f504adeede782e470148527848cc067b83558172a83054bfdd6100fbb09cf5d236e59d9e09c85a1255eb010001 \\x87b8ab6f973783d9472d9fc3aa8b0c1b51b79e22c28c797473d3a706048872470bfc9075681b1d9f8b4009d174d62111ade14288cb9221b95069a9e7be4ee503 1640170407000000 1640775207000000 1703847207000000 1798455207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-103 \\xcae82e83d002aee720ae611be90c65f4609493fc11446a8b07d416e281616f54997e8f915a8fd4a099ddd5898a5e37b325efa657d5359b8b40ed2a19f6bbfc67 1 0 \\x000000010000000000800003a4ae9aaa65a1b9b2b0739451e40ddada1e642bb2145f2e315c493347027ad60f4e023835641be7c0b635821ebfc28c2f72a5623d17367352f725f0feb202c927587336d95453ab0adf9170b652131353d53af521c7eec252558c77233870843c94e046ac4d977e0ec60bcd38abf03faac396150bad5e0d1d5d0640a62714c357010001 \\x2d975150651fd69861352deaf7536bc57d37db8d18e1c47ea2fe5458e2790ddcbac6b99f90a20cfdf1db92b19840ad8c80fc5e5e35756de08bca7e474c1a940e 1655282907000000 1655887707000000 1718959707000000 1813567707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-104 \\xcaa0bba1eed96cea618332b401a7ed2c3f5ab3b43c2837837877de7e4d0b1e9c7fed63005a46e37e093c3bb07f667117fe4fee923517de53ad029061fbeb4e26 1 0 \\x000000010000000000800003f3f490c0df747428993eacad00af066f233fb9ae501a374c40deaa6e19cd019413822ffcf06254dda1191652ea403aa694ad1544aee863edf6406063a8f6e2b951d46d2dff09d5d957a4adc79e78e721f95301ffe310b08b042f73730adabbf46d0e3562aad6398043315de4bd4d4b772d7ee2b45227f8b3c7cbb95f3a11c1ad010001 \\xf8b92251b571162e743164d8fccb57dc53ec6f3fca6bf8af2ecd906f6b22084dbf6166d8e8d040a6ba280f16ddf598c3bbc48e1825317e88c6323c377d14ba0f 1643192907000000 1643797707000000 1706869707000000 1801477707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-105 \\xca604ad4aa1a48f5a4cb020ae1c41989ddfe6cb61649cc42843b8530c80c3bd8a4510e89b2242d3c1ba960e2e17ba1a73324646ae80ce46ab9d544e03f9e7bab 1 0 \\x000000010000000000800003b8eec2b600bd80bf7c2c22deb08b47cc938002b951085f2df287f9f4531a51a3055ea03d8aaa192414ffb88e3f37e9af86139f929b5bff38dd10632439d7b4ef7fab869f9f2d57068767b304b03e165003560fd4da31f18a4b50bd893701b05a521bf499670b802bb7a553739e9d83586d9b0cf01fb48b8eb44be5f1a749f00f010001 \\x0c9f327b98bd9449ab10225cb129e4dacbc0af9d57fa66c1a35a3a918b522b01a90d97d594c1bd8ec8efd62d0242a2dcc87580bce970f9d60fc8ff4035b41e09 1648028907000000 1648633707000000 1711705707000000 1806313707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-106 \\xcbccf6edc8499d511fd54ad2104c1f085b702bea91a861923e6f11eb222ca51362aeb507a78f846822d337e2656e57cb5cbd3e9c04c8e1d668ee2219708bf6a3 1 0 \\x000000010000000000800003c3ad9e8e2ce76161a1cc2ca2fb55392a812c6bca178a020bf78366afc49f5f952db6615f66dfc164df1a326befd1271838a98dfc60f5898eac5da9492875f7b1192aa1b9608ed6249484538863e4979fc0f3a00da0862c2e2934f3351967cb330a22ba35a79014bf3d58e117d356dc22ed49c10b07a42206aa218576ad616bbd010001 \\x511a2c9c4addb76045aa830d48333b56d72c45184d0da672c53dcf0262ffe8652cf0bc90a4fcdb194491b69b3194f029c6bb94f87a7a2cadc15feecc2a80380a 1641983907000000 1642588707000000 1705660707000000 1800268707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-107 \\xd0003b0d9669af132ca63c56ae001ffc39bef4b4e0e5a792ecb52c5755bab1fc1efc0c00e55f77ceb287264936424b0d31407eed820cd5c9a1ba58e66094c680 1 0 \\x000000010000000000800003dd560046096fb8b1f8178b599cf633f94e0ac0b62e361f5dee502543697269a1558ef2e3b3972615462363492382671ae8edcccc7f114f74172d07bdd677e8b93865fdb6a8dbcc5f08422bfb4bdce80d2e73b055c80c749d64e0cdd92d473054c25455000d82d1c1fe40cce550c296dd7ff190f3c95f639987afea300c83a2db010001 \\x81c57fefb9634c1f53a7a9a2005581e2d09edf2d0732f0fc5ca5c596fcdff4455f2b04bcf077aa7f44a47052750de9a985e6ab559d4640cdaf6ac30e4e2a5104 1644401907000000 1645006707000000 1708078707000000 1802686707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-108 \\xd1e8e85e50939a454f1b60dd887335fd5d7e6ba1e3be660ab23a3067ffb0c34a4286608f44cd47c7095f32f83ca72e1d6c4eb8ecd98bc53cc95df17c01244902 1 0 \\x000000010000000000800003d82fd1dc03455d0cca6bc1879163f8deca051ed4cf0ef00a2c7f6179a58d11f9f323f1ceede3fd26b2dca04bcdbb77ac19fc3c6bfd4b61150dfd8c0e26ba2604134efbbde600e3af9ef1d69e5cf70d549e286225d2862df357cfa2cb34def0c6cb77154fe1b6632ecdcc2cc89829096856a8049a648a7fed61227672e2e4dd9f010001 \\x50e7e20a94a008ca49ba58c78e6381658503f34ca09da6d9706ec45be031fda15dedcf827e17cb598ace30e6123df0ffdb1d50465eafafa6bb859639ae72e108 1640774907000000 1641379707000000 1704451707000000 1799059707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-109 \\xd46c1eb2b15beb565ef19cd754a70874eea025e2747f310f62668a8dc077860c7e93558fd736beb700b85a8aebb40e5d39904f48e90f1b3ef77874f0de19ae69 1 0 \\x000000010000000000800003be277c85c858eeff4d4f06abad250441dd1b25291dddc6b4e1a900943717c7555ceab4e1328791d16b50d467b41aee5cb53c202452b225684447676e2c6dcd8aa7dc31542e4881fad4bc808b2f1ecf776e7513e9d1c95373460492d8c4ab90a72b1d1258f9a82c9b67366b26b7ad19e1dae335cfdd69fd0906b21624374d2e11010001 \\x438b27a767ca8480f3bcfd5b11d4a3df23634ecd36fc05d918bc6918b250a077ba6588c57ed66f6dd6f890cc830b1b4e91ddcdc055a762094a1f1394d6086109 1664350407000000 1664955207000000 1728027207000000 1822635207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-110 \\xd7984fa508f3392c86b8f9e4b8c5d66a5800d75efc71e5b24c1b71513fc8b1b8685344c0f1e6e3e590daceba66f9fde02d0fc1cffaafbeeefbb323a62c04e976 1 0 \\x000000010000000000800003be66549d10accddeaec4f0e020b3340a68391b888e7df3045750b2ec3f4da0826b69de1c45445013445711342ab7ab39a29a4bac4b51330bf8f6826005c045ecb74249eb173f0638acfc621594e4287dd88773fb6a7591492f7aa06b37f4ee6eccaf79bee154bc745941bcec80d76131110ae5f60a682691592b21f37fb90053010001 \\x6db9a2030e6b66615e3b64f3600a6e3503eda9e5c6f901e8348560dae5bdea66ef0ee305b168cd3447eda103d6937048c159152ec63aee96c2ac5208dd5d6604 1666163907000000 1666768707000000 1729840707000000 1824448707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-111 \\xd9a01c1063bafc8e6234b14302eaa3efd2f98f0c3a9a5d2f89161a5f7689117f4e7bcd37ceb0070763e333ee6b0b17f9b3dce5a904c0e662c8575a259a532303 1 0 \\x000000010000000000800003c2c8b245290b37328dd1397710fe444f007e0eb445dfc1425c3864cc896cb1cce1fd5fecef35e99374aeb4dbf406a4464a2e8e0db3f2970de1bca3940be5f5beb7aaeaaec5f864215bac78a419232d5471dedce2bea401ba0e684c6bff2d8fc9bf8ee06b3b3f52f003b6f9eabc4e0282451cdb421880feaee3279f3223bd94ad010001 \\x889b1182cb8f35ed1f8c96b972e66c20924f73295b28f00d0d96e56083c8fd64837abdc520c99f42613e48698b590d7eed457d6310ac4dca2d40c3d5ec90960d 1663141407000000 1663746207000000 1726818207000000 1821426207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-112 \\xe1a4cd966e8e48ae37270e841bbd6663d171f099b59db4ecade266105a911cd194b6d597238e026f553b5cdbe372cb963f75aa4633874b09ef52b2d6875bc20c 1 0 \\x000000010000000000800003c9223a11871ea01cb6cf573404a7d5b2bf34c5ded09a6dea67a2819a31f4981a8383b97de72ccd7064ff1c714f9bac7a0ff010cf76a144c0345b057f1e276444d11af827e6873c74fea2e5e463c79a382af29548bc59bba5c4d8a1ddb868d5def058d5849eff40560eac09a147ad50027464042e11d606d4b304bbd1f2ab1647010001 \\xe745b9ecf66812eea8bd21a9eaa913890ee73ad31e1c7c2f264f68b21a3b765e8a31fee330512ae1a1f0b70d977c9a42dc560e84c5453b53b952679d63e4c006 1649237907000000 1649842707000000 1712914707000000 1807522707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-113 \\xe44c044ee97d376c8bfa55a296d8e9c72b6301459ee8782e57573c09916900e448877a4d9d4bb019485aabff67804259fe79e68a287fa8f086028f9a4a24e997 1 0 \\x000000010000000000800003a938fe9eaea59ccd0fdb326a28a4620198ff7dd0874cc6978fcc8f512bcb875440344370f26fe9fd2a0f4aa1a1853c0ba8cd55033bbde5e06108f410663f765d3ec4e0848c6e3a2357b1167d3085fffdc3c109368ea5fd42517b12d7a5294a1b683dec9dbc2afaabc9244b913d3523d61e69968039a0ec042b8df2f6ce47fc47010001 \\xdfc05858379ec496600ecc44b76fb0386f25f0ef11988807bf8be98a5e38704531ac06e9474debb07d22fa6c5e18e59601939088a901a4fd894c6ee5bcf51f08 1657700907000000 1658305707000000 1721377707000000 1815985707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-114 \\xe61856c28ed94e93bcd8bff0f4b82de95a8a0af85b09a24c728988d8441d8491c43f8a45103af3f3c95796cdb2ebe719a16f15053e52e9e8be896146d8eb7a06 1 0 \\x000000010000000000800003b55e71fd1b61012ca6fe26f9846be1232d261ff827a23e98aa14c4a26abedc80318290dbf5cc326a15aadd4e4124e95d848521d375b61edf7649087abd4091a6ad988af2a88aae98973aced2900680927a5229abf3609b9d5532d66247603db8dbabc0c3b5c72b4bd0a63f718a598ca1a169dd1c1ab78c6a2f50d38d3c7274a3010001 \\xa6ce3b8a80c26ecfafe1734dc18218d392de526d25779661a15643dfeafb7d324446677baf2b102deee25b022554f37774ec800f8be60b2cd2e61ef58f20ef09 1653469407000000 1654074207000000 1717146207000000 1811754207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-115 \\xe6a023e5713985af543d4bfa3bdf54121607837db7d1138ef1c4da3036d6a3df75a6b95d5b9c48a893ecfda922b70f3c59304abed0bdbc792b1fcb8b758da83b 1 0 \\x000000010000000000800003f655b424d8d5b785d925fe12420393983a23798964aa66a19dc9f80cd345a6c2caa9fc7a07f1b668a1012e6ee23fb7aa377ab9c595a2eedaf4152d0bb188c247342aa3df2199bc7cc1f158a1fb439e7c3a6a159afc170306001f7c222cfb806d0c0f8c454ced41def65296cffea83fafa37d90687c2ace4d767a0faed07492bb010001 \\xea9c994259d69c9de69a858f0cb94fd9d48c19237a88677ec7ea33bc623286e0fb660c753246eb2c70d6077818a7a3a0ca9bad4ad1352b4d3beaf19df4807a0c 1647424407000000 1648029207000000 1711101207000000 1805709207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-116 \\xeadc70edf58b1f4b7b08cd98d7975dd9f879d05ed63444f311a2ab8d0bcaa3e6a3846e2d807c36e87d077d95d0d2f59e228f0f6b927d39532a1ed4ddd33f0c76 1 0 \\x000000010000000000800003b4ebcc0af11a01a273a3756c4a9cb50fb4bfb4d36227db829c09c859a8312d3114e454e52b154da61ef6cc6799cea434e11eb5332aa12943fcbe109ba6e2d2269651b30e45ce533a5dd94492eef2a5e259210e8a1d86b773ad811a05ceffbd7b6791ec55d5d341572232733c4511cb44ebbec44db505a43780829e1d224720df010001 \\x42e07a2bc9f2618f1372ee6016ea9d5c5fb946fe00f5d27e5b172fd5c77ca07d871903425e3061c23dc6a6456ea913cb7c92a1207e4c8bc97e166bef2676510d 1638356907000000 1638961707000000 1702033707000000 1796641707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-117 \\xf0705811549d6325009c9745ee9fe372cfd5dc54308f06adedfd07f3a98514d49eb0a4d84bbb91982a000693f067c7d466daf9d019a23f5a327f4cce908df809 1 0 \\x000000010000000000800003c340b534e52e4d660d31b7947e325419ad7eab50b415f76b1b977cf6cf8d84732bf25c5644813392432bedd2b507964f1f5174d3ae2fe87409e43f3bfe7bdbe1d14445831c34d1de490810793cf668ce6b621c2178164fc0ce7c3c08433b0d27ea31f5c88841af7c025d2d998308b96230044db1603c1c2bc28051beeb0da8d7010001 \\x709690c1b5e359fa48e4931971bc7dfe2136e8a40c2415b004af6c059d515efb4609b8df7f0b8e2ec987ac91ccbedfbd97d3e5cf34d7ce118f69744eda82ec0e 1645610907000000 1646215707000000 1709287707000000 1803895707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-118 \\xf168c275773f86999fff5a5d23892af1bf50e673a53637c8358aa1629f928a4575751381e70a4b22d0661abb2864ad05629ff0e1656c2226121cb265e0204249 1 0 \\x000000010000000000800003bdae2e591559fdf47fcea130f71dba6b421e16658e865e3975ec0f560f2a4f686a1fbe96b01e896f6648504fef4ad51ad9a43b6e3f798ffd61a4976a8b1faf7224eeca269c52139a357ecf950cae3acf4a071d0bfe4abe794c4a9fdf476326d7911cd909377d60a38698fd9f8c327299162976bd47a9dd7b7411dad345c21e41010001 \\x72565d2de1ae91fcfcc504d094093d3fa1948718a6243106dae261d00a41446610306a12768601f1cf2ed916e3d1b673191cae05b8f3bf2308d818bf7e3a3106 1643192907000000 1643797707000000 1706869707000000 1801477707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-119 \\xf548d688fea8bca2df101ebc9d305b07ae4ece3d68c80a3e5902211c18a8cac74efb4b09ecafe2575025648db64dbab872434659a4c0e0db6028ca83c0c461b7 1 0 \\x000000010000000000800003e23e349d85a97c9d572c7b9450661df9e42d9fe81a4dbb71b268a7a41f6be40e71d82854fca9a7575ea7d3b004f73eac77676df4e8b075a1edfca134a29655d1b66daebe6b8654f53af262d34cdc63b3359db17a9d22361211d31e6b100ee57ad6a70b107f22b87461e7a37414b299c76ca309519c5f4688b1ee46e4c1b3f80d010001 \\xb4e3e3e4daedd99fac5735461a3ad7bb4732b140cff0a8d7808cb581132d4910e9990ae80ee3521c7df0c1a3bf162ea8f14947968956d08563d25aa22b255f0b 1663141407000000 1663746207000000 1726818207000000 1821426207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-120 \\xf9e480430f2ce6703d905b4b4234ab40c7b71f25b16554e1ddf5b3a157acc448c0f9b6b2b0cc603a320ab09b887310fb2495f4ca1ba86ac439844ee51336929f 1 0 \\x000000010000000000800003df4cc746d486c5bef3887624e6bec2c0499f39e7b64bf7c0c5e69dc66e3820742ea062a01a2bce1bd1ab81f55e025e5a21d126ef8f9f7fd2d452b7441e1e5c385693a3db59762b554e908ff465bc1be275fefc2ce9d9d5c4d198414bda9072151733a27cfad464396a37ecc21b3da5b7df0bfe6836e9a569ab3b763d9427843f010001 \\xbd3390c8eea521757bb121c4520682631ed23e9d01ba1689c3e414baf2c9b6025d3cb469d5061482bd58c717f254d9cf9d0a88f626f18f0df81d1301a08b2b0c 1658305407000000 1658910207000000 1721982207000000 1816590207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-121 \\xffbc3f0ac66e680c561a40ad6637f76e8f7ab756ddf47fd194dbf9832789bfe3cf4324037cb3ce09fb716fa842d7cc5fb4db3df0929c34d41884db53807487db 1 0 \\x000000010000000000800003c16fcaaab8ff799095c5e81f002bae76e41184615e6735d2f92f9c6fabe94afa56377505d62a76c152a1f01d90a1fd6ff9f6b99a62b62bd9622189bfe30196bd82ac5f9c0bc450452d539be15b63615a07c3fc0b96231e3308db3ecfe2fb2249363cb2b8aeded5eb2b6e2f317ff04806f2ca8e37230c19c1a398705d2e591763010001 \\xc3a7daa14613cfdbcd04c78c5a43ef2825f0b12711dbff59f3e99df551e1d4ff9ee64e6f1fd972e3942bd285170efc4351616b88f567e5a530e8d306d3f27c0e 1660118907000000 1660723707000000 1723795707000000 1818403707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-122 \\x02d9512fec81b7bb0d108f151fd98ff9ddb3ff3276dc6263088957f64efcf653c5122faeeb20931bc543f911e9655d03020e529246bdae4029b35d4629b6a3e9 1 0 \\x000000010000000000800003bc071db7681be3c16871b42896aa2b90ae61baed7dc32d6752c426b4eabe8d46a90b3af508d8837ffe2fbfccc7de87a7458f3e92d6b3876809be579e8d02d5ca2b1c8137b413fb0190134f959dabbd3d674cf9222f2c638c7648a9bd0053e46e00e682276825911cec0aadcf285142fc8d858907663ccfbeca69d563656b778d010001 \\x2b17aafe244676ff26f183885a7c584cad824fde01f42a8e08097f0e3064e0d1cf9defe29f7c9980c7ff854b870a4f0dbd09384fbd41b85a1927b328f6c5a606 1642588407000000 1643193207000000 1706265207000000 1800873207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-123 \\x03d978d97fc860af7727d4f1e1bbbdd885834fe7fe5323e9d8b557afe03aeec767beb8af28ea2548c68e3afa2a1980eb91ac2f4a27cec4bbf05212d50073e96d 1 0 \\x000000010000000000800003b29f1ad37fda3e260384954ee3b63fdb55d2a433b6e5e1b53bed449cba9927f377aa6677e70142e8caeec6313084b53b6ec163897c0363f25304249ddc54b17ca598c616c4a2ec9c0467c67d9871afbc2e6d9dc3cbfa949dc517d71de42a20cb6366fcb1766e6294c0c504bfe548b29820df218384b2141ebe0300f88f60796f010001 \\x45c9945afe16ab384152a992bc61a3c1d8f6ebe5ce4c08b6b4e59687f99c5aaf8fcd9db64c6c4e189b2086ee32e16a5ecdff1ac13159ea34cdf5f838a4bd7408 1644401907000000 1645006707000000 1708078707000000 1802686707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-124 \\x0405dc2d0708cf80b12d9262ab3afee47159ba8e30cd6929a45bb990f8f5bbe73c2179e0e2c7b759a1af8dba2d8eb3be43918ecc4cfdedfb3f65d0e010409504 1 0 \\x000000010000000000800003a67c14de480e6e1fbfedc1d6a289973708d0cc642d28e4e41adcf0ded4ae87e5395d1bc254fcc97cb34269f79cdbbf24a7a0bb68e80b7acd914ea6604ccdbe68f479c21260f4bb0df9c52f99cfc7db436597462096e1d60a0262189a3b54035948b0829c7ea5db7d4a35e888f5d36c21487efe39b8840eea75097eadd4c76c25010001 \\x3c371fc02bd67c079c610995267b5da580d4f693ed86ed09ac0b1a6668ab0deeb3d97023a20fb976c86b9e1cda1dcc6862c495e838f9c6036c796d4f671f1202 1658909907000000 1659514707000000 1722586707000000 1817194707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-125 \\x0619665d441a506b108928b1a054612dc1f792b9bd221b9b02a3eceb7f23511e219ea50903dcb7138c604056d4b44ca6dd2243004d3c32079ac9209dc5aec028 1 0 \\x000000010000000000800003c1924a68b3c754e6f55c34b561d6f8056b2a53e020d73082556b01592ddaea4cad06e331bee22c3de913816c2a5bc767f90be775c2b88489ec1e23473b4bbbca70053724a488f052db2fa55dc04c8b456c902670160196f79b3a7bd84bc838e4a54c5efef967300d1f7d8697b0bbd91be0b8d3701da4134621436ef01249fd6b010001 \\x2adf2785b9a7b349d5cf2da4e50dd63d875d218c2980c16fdb14d93c3136028bdd7da80ffa0f92440dc158b38219f14283e703d874e1668dd3904ce619bc9c0c 1638961407000000 1639566207000000 1702638207000000 1797246207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-126 \\x0d415ef4c3b0b26416acedc2a5117f2eec5071e3f1104bf5e50ac3fe0be7a83195db0f46084c98342d4c3f8f54bfb88de57352d79a8600eca83e3a7be35af4e2 1 0 \\x000000010000000000800003bfbf399584f107234751071c9099e18ad182ac3f16a222278f7051a0440d502ebc96aab84d9b2d4d2ff37c8e78cc2ae793845c8020fe0d6633b1076da5dfbf6ad749a1a9b20d595faef6923172a84cbc0ca1e01bf7f64ffc0f6b2004933268d19da6c8eadfb3039c3f1ab986a9b303b5755d4b0e5ddd6cad4aca5ad9823d639f010001 \\xee8fcbb00634adf241cc3a2868cd6eca8869ebeadee57e6af24316cba59a71d869972a269f0680de405f0d0278c7bebd72d14fd08bad788c9421128098a3890d 1663745907000000 1664350707000000 1727422707000000 1822030707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-127 \\x0e45d91b9094f60271dc77677883f27132202b8fd18716bc4f77246622017418bc1503dab1de33a7fa2d66b43b5acd7c23b8e6d4b2fd4cf718c676147b65c6c4 1 0 \\x000000010000000000800003e06a438965c025edfdc637215fbd2916df94bd248f7289a63ddc89e1085e33876754ad111abd200eee57ea95554f5544fa1911de1f4af60c11f8de91234b15d3ec146322b1d0c307d6eade9feaa4104848ea22350035c1fb456d90c393663b7bb0151546ae85e83230c945688bcaea60e08b04510cf85d42a76b57ffb143e221010001 \\xe4c0b7c4a4c1079a2043b7a8cc9fbb0e48f532f0990b0f0e690c3bf4a80ea70375cfc8dd032cd2f77a6ae81f78ee141d03deeb90602da62486f6ac70ee5ba003 1663745907000000 1664350707000000 1727422707000000 1822030707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-128 \\x0f39427354adbe8d2fdddb4af42db250b666ed321b3c69bca9e0eb26a3adf1cf6bbe45cc0789d2583137d5cf88b7f46b197b0f89702fd21399edc1508d7f7873 1 0 \\x000000010000000000800003e0489fef040f6356762bea9bc9f245ae3e82c3e6447fee37c921df4789ae89ef12a549727a2ac46b7f6c86f11be89544be03fb546b2cde2d773e6e8af89b8d6658f9cf40dec51d59b0988e94e818a56609782719f041bd67e97acc629d09d699cd54a88718c00d40ab89aec4f94b8e8bd5f1a5f2e5bb56d54ac1a2514b6f969f010001 \\x53bb398ce379c8dc1612862a037e5f66dc60bd8c9a3a489e8d79ef8d68b7d58f73691bd45fa70b28b7d728bb7189cf79d6ebec342854b09a5a183a918ff37c04 1638961407000000 1639566207000000 1702638207000000 1797246207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-129 \\x14415f738567d4759dcbb9765624cd744516e3a82115d44113db9698712a0dd3ebd6a02fc688ef698158cd487451712324a0c6965b310fa05b16d186c11b0eea 1 0 \\x000000010000000000800003ea15f6416dff513922f6d18faceaa66f2f529804419b4f945026330a72616292e7fd2f9aefff885e2e21fcf0b9061d05118ebe1c73513a219713fdd824662b0cc219e30700af3f9c3f1302a892e79362d0a3f9f5a88a72ba205df0d254a0b162d4ee20ca9d10bcdf8f1429c396c8e0eb1bb918983fb38249c45e21eea36022cf010001 \\x820f39c04638c220b20a1207a46cd9aa478b3922f35009280ce4616973de8eaea0229426cd88a209cdcfc4ce1557efccd076b126fe2a0a63a6e3a982a5435a07 1659514407000000 1660119207000000 1723191207000000 1817799207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-130 \\x1a61bfe7bdb02a0293fe86e6432d005367c4d8c6dcff837faf8c883e7535a22bbd501ff00f94e2bd1d785b1972b6faff67ddd8f2f52fc5c9389299b1d1aca30a 1 0 \\x000000010000000000800003af03ec407d75aaa5c96e2ad933a36a8e8464172df8cd5c6830bd22659df24de94b0c62e9c65e593b63d4cdd069c13c416e8f744061d751aa0fc5961aaeb6ab11c1312c4f1f2ff1a73fe8e873e118a00dbf753278c2a7f153af4de0deda4620fc906a42a640bafa26b69f4d80fbd415040f8dd6c41adc9b901a5399cd7ac2f981010001 \\x1264f8a1789ecee34d4adc565e383f24f16a9f702f43546a5b5e42f95a8faf71cbb3d9ed5d51b8c90392654c5ff6c9ce8bcd1c05fa9b5d75da7496f761d9890a 1663141407000000 1663746207000000 1726818207000000 1821426207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-131 \\x1c19bc3ec30196c755b0b783166deddeb076650a39bea9b7012b2bf333eac993cd7b27ca0d3b33d9dd64bff35c660324127983a65e0ff770bf66a923dbbc774a 1 0 \\x000000010000000000800003a99874984f6d2a4d961de107e21f2e87880c581aaca76fb954bd861babfa34abb098de91532d5bb4e66682ea5312902ffd0362cce2e65ebda71b7de902126119b14590bc9b480980df1c385fd0ad014fff40cb0f7d037e84d242a175204618345d54d020d376e87824b6ea8d3296b5990fd1d3b890528d59ea22b2c093462b99010001 \\xa68914f0f708d3466be4fa8de26c7544d3b98a8ea05b4940a1cfdfce22496568bab86a17260d3c0a934919abe129726bf1826d10527adb798d31113e465f3900 1666768407000000 1667373207000000 1730445207000000 1825053207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-132 \\x1ecd193bbd6f272a328e9fb633870b1190469c0a526308ee34e08765d66f2a6814695073db37bd71556e4433e7673dd2d92c1f4fc798c78a52bbc6d52ffb3eae 1 0 \\x000000010000000000800003bfb61ce1504086cb8602f09ed30726f50cc818ff62919a5f8238cbc342e8669578f18fbd52e707fa0116135766640f298bad209db5a4003734be68bfe932274a60d0cee76b03fdac131d12941fac3f2907bdb2d3118f96a905da4b30d5691b6d740218e9d5703854a721abce31fcba447efa87b025e220872b1a0f7d83cd1929010001 \\x5e06e975e049e649a92a963e35b8947d784e36ff633704813618c3fc1e2ec0db60cf775db3664b596830f99fccf82d38866f7d71e56cd04e0d13a35fa2a22906 1649842407000000 1650447207000000 1713519207000000 1808127207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-133 \\x1e85a80703801ede10b3db8159ab6fbe589b6aa85d88340bda44a8ed78cd1d44088bdbff51f33079e32b3f2bfd6e08df4b70a5c43b6538bd2946832487744b2b 1 0 \\x000000010000000000800003ed3581a9b050552800d1b1eb1e1a22308b890dcde2956d46b3349e6c1b0228a504fbcae811a6c93bf1d51c5998264848a09bf90375373a1940de1c9c184cc816e19a698d82c480037afb1e6aef0734d24240943eb4946668ba4adb29fcd784233e17c1d36b1cdcd14b02c4bed74f42c506abdce1aa61b6e43aee76512a8718bf010001 \\x0f0d2a273340c7a0aeb572b81eb0970e08436bc860f68cb985735e586314d6a6304931150191f96349bf546a21f95762101502745aedaf4019e55d086de3c803 1664954907000000 1665559707000000 1728631707000000 1823239707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-134 \\x200d360ce14c043039c867d013d3c7a635f8e3fdd1154823156147a00949dd8067efaeab8c640a233e04bdc3e34ee67da16bd86d849faae6d72bfd2128822aa6 1 0 \\x000000010000000000800003aa3558995ed48a7aa6eb2783e30c142f32922e5bccf8d922eb413e94f0fd324333c424a880e5ba8a51fd28e57ef3dc8025594df71167f4b095906d142b54c6ac39007e44935789af6c68c29f101e8b12b9a708b5bb7ceb6ac2f34ac53ba3598c4bf3c1d880bdfec3d4dd2b251861a3c473e8e5a6e59b758fb2261b230b17d513010001 \\xeb4bfa0aa732d504aa10d23a11cbd515f13b6546fc31cd14b263c68cc8043ba8b263e7fc595468fbd1d64f739c14cb951b74f054a88e7a4217656aed6c05ed02 1646215407000000 1646820207000000 1709892207000000 1804500207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-135 \\x219da360804fd1bb2c3dd5b1f60e89489cec06b0058aa8011a97eca8da01dfc77219286d39ceb330501442b5c7551936835d1ef164d17c9993731f1f8c46db17 1 0 \\x000000010000000000800003c14eb6cb966212ac9cc3ac1d085b36a521190de27f67b54c565ee37d919c299baa87df24947f0ca2ad43eb986a47e5da3fd9639e73079bc234c4ae6dfd325d7b74fbd9dec74f200c70eaea91d486de572c010e152d587e0831b3741c90769ae280bb9d888e78bb3c83dea88939585c4f598c6ca657b78e0c47ebe6dd55b25083010001 \\xb82da326d3d50d8d7157d94016968744cfd6b20e5224e8f6ec28773aebbc8fdc0875ad0ecabd879cbf16fa8aa2adef7a1e9ba276c602c111c1a9ed4f64d1ac02 1667372907000000 1667977707000000 1731049707000000 1825657707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-136 \\x22654a329b94c15c36e145a22f2c79482331f047e1a9dcc7da5219d1dde505d53f2676c0079be85599eb68ca4edb888b740f85e5636a21f7a2daab37d3f712b3 1 0 \\x000000010000000000800003d92272ce2a68f4cf499f7603223ffdb4d9ce31f8f826200320863e50c3b95d48a49d0fdeb4409f6525efa8498db736524db370e1891c27f4fc5721d955ed74a315946795bcd975b30a77faf31eea187d22d90e23022785ee6187da12ea7cb67ea77f2cf2067edf224ad47642a81556a79775d006bd32d721276c301c31a6f287010001 \\x662b047298fa4e886cde31508c1487aab11e7fb58bcfefaf9f75c227a0daf453dfd5feacee613094aa96027af11d6b9086cf574451550d251fb7345d33a3a601 1655282907000000 1655887707000000 1718959707000000 1813567707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-137 \\x223de7651ffbc593024c412cd41687230b076e65261303270b0fb415b37636d59f5277511d1373b30d16c9e3db6ed9fd5e47c65ac947b804eec902aa90eef005 1 0 \\x0000000100000000008000039dffc9045d3c0af1b10c3385a8b55b031c4634211e2803b1a11ab51eb0145bb56a543565cb334c4706be9903852f5ddc144cf5f95bd1e41d96986ad4cdae70e4df623a7b859f6ea926659bec8345f99d530aa4b88b80ad32c15e0ab0a64342bbfff336a812dffdfe16302207aca8c670406bb0f9c24bc49c182e3ded56d477bd010001 \\xbdcce7ad7e16439a46d0eea6e456bba0cd8a8509a30746be7932e7ee257645056d695966c0d885119e86487c2038d1fa683cdbce6467581972b659f5b1717a02 1640774907000000 1641379707000000 1704451707000000 1799059707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-138 \\x2281463600a2be40da4c1f20225dc54a3246941ce26a94394f28eba8c65b77c4843d06db4675ebe087b4edef81664c86394105d2a3c0b4aa040e2812513e2d0a 1 0 \\x000000010000000000800003c9a5fd76f4352caa8ac5d0698ac2fb14f2e87d19c9ec3af6e2cea251180ba1dc4b8f743d20e843615a2656e0aa2b292aff6cc71adbe08608a231bfc577fe00a5d03e69b869a709a82f1129fb53487384a1121e752c7394edee4dc5899092a023e5ef14dd42bbc5c3ecbeac71587dfc62a38a93215c06dda22542902ce2b1dd5f010001 \\x897f5d7ce3f62b01f114ab78898a268eae4fe5aa915d3fe12dd81f77586cf02e14fe9d59cdcc4686240422675f1a625df67dc773bd8385a0e231113a7d5ca80b 1666768407000000 1667373207000000 1730445207000000 1825053207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-139 \\x26796ec6c42987fcefffcadf2d82c2e5617c39063d9bf03760e39f38de8613501dc24ba2871aa2943153c930079615f645634f96ed2e58c58a4f9cb915c89d3c 1 0 \\x000000010000000000800003d7b7eb8418618c6862c749c0a5e1697359cdc29da6868403809bd41f281781ee9f5c6f1894c932088789ab79199856d2c5e0535bcc84a0240fb678be5a543d921ddca37e541a2c631973d60e5289ca3e241c8137afdd7061f7d3a4b4348a54a3f01616b2c709cfeba3e7463c017aec680d6e55ff21b47c5896f8c20aa387f2e3010001 \\x8fff2f5a26698681445280a03a64292a2b197317b66072d52f1c24dbe1c681158386d7cd6fa7957156b549efbf9720c9162ebedf31162328bf9c6545d1652304 1639565907000000 1640170707000000 1703242707000000 1797850707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-140 \\x28a5cf15b0dbd07ed999731ce6c45e2caeabaac57d0e98f489c289a089b0792cda4aa95d74d0d48e0a51c625671efe2e589f79a0d503e506af870afb652b6988 1 0 \\x000000010000000000800003ac7d9e9144feaa347da5084c48f0aea712c994de7057a53217f573ce5160edbc16a225c0f1d4c847f9b7964dadceace4c7eda733dc17dffc944a1f48ba8bb99594c1bf26f30130703e81a1f6417d8a01e4f4d4e9be4363e4ca17bd4694d28bacabf57517e2d143573c15449c40d5ccc566f1fab09cccb7304d0acc2620da76a3010001 \\x8c91ab04561f245fc8ac10dfe174c84aec07fde72a67e4758a7df9ba1f88ab94fde053732524dbc847ccc71b5bae07d8d0edf26c9eeabcdfb722a96f7458fe0e 1661327907000000 1661932707000000 1725004707000000 1819612707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-141 \\x2ad1fcad9164b8187c2c80e4718503e2da367d1baca43886cf7270ff431afee2ef942cc7cdb9ccbe751be02b97b3c339026fdef00e73a1d4c7a4f26f07fe84c8 1 0 \\x000000010000000000800003b89e2514cd90eb04292fecb4c62b662aa6ce2d593ebfb0c7a5eab771cc1ebb7a5f57f3079fd0f4a28d3cc86eda4487f3d806aa7c1f8d757f9fc0d3ceb2ced76f19f7ba2cf9f3278dc59f6fe864df43f466a0705be5b3ce68c8608d2b296c100510e8dd3b8a595d05b579a059744605b8119e2cb2201418e12cb513d065e31b5b010001 \\xb484c74aca2f717caa5ebb8eb8e049ecc8f262b16bbda5e2bcdc631e5706beaf2e1d3a6381771384319a36348718d492090413573927aaf381769c79806b4707 1659514407000000 1660119207000000 1723191207000000 1817799207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-142 \\x2df55749f82c6c3babe4ea950439be13436d788da36beac3a790679d4c344dd5d660e4f439fd0b637e71a16f344eb24c96ad51080af330deca310b6a5909d99e 1 0 \\x000000010000000000800003c17dd3f71096b68e6ad72181b2a13dec350b53f8f888d5d32af1da4d2a8504a0fd579c7837ff9be585e1cd547d969fc2142c8ec89272b517dc2594e2c6e54bed0da1b917b4c6464afcfe490f898de177bcf0eb18c866f6b1361ca51b4ca2a2723bd865f5950287c97451f8ea4c3b9e56a852493fe1b5119bf31ddf1ca18c6403010001 \\xb69a0cefad9c044f9c3079125ee26aebf8f3b88f0d9b5f537644040a74562bdc125bc4dd910b86ce62d6cfb2f323f2b62281ccd8309779451b74083644b4c102 1663745907000000 1664350707000000 1727422707000000 1822030707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-143 \\x35c50ebaa84a5f5efaf79d1087449c8ecfe64029d3ef59cc612db7f623958062824293f9c5e4123f925b69bfbb825012a0fc8b1a5677a1bcee97673782928950 1 0 \\x000000010000000000800003f0d8caba37052691c1618a7e1a9f0b81d139925d8c2c96abcff30c02be154af9fa2e83777fd06d2ab346a5a2a2c4b274cde546c564ee5a8cf564858f4f6d9cf87386bf14eda190a25f00867e308a82d48b6ef89144fb2966419d9a6995957280d5ffe37bacc3048e0580b5c5ac2528f681fa40dfc8f84c2be2ff3a0846479a99010001 \\x7fd7827aa9ad91b91d81e1a5076f3a6334dd21c57512c16fba7b5881716f7f5b26f85c924afec43ba0f4cc3ee8e3edecf60466736485949c3fdd30f0541cb505 1642588407000000 1643193207000000 1706265207000000 1800873207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-144 \\x3b71724482c2d496cbb897313d28020a959936bad8d70ca727881f197eaa0b03983d602cec09a8a8a1fe9dfd3a3dceaa09770c24cfff42c6575193457c31bc7b 1 0 \\x000000010000000000800003e9da4a2e0b1ff2d0e379a94dc39fa56510a3f0709a1924f6a7983d7001e2772ee39b1d60345fce7f71a34166c31131c152be117f5b14b00c4cccae2634c1accfe9bedc38fce71e85b8d1d5506afc3b86046ceed22403cace09cdfa154aa9dd98daae3ae3aa3b4fdb45c8c835f1b21eb742380747828b5ba76d25447c35fc8a2f010001 \\x0e4652b40a057be76cb123f4cb428375d11c39d8e9540c37cd532edccf65c06c84c664945d59b9d2067f10f81de66502aee3a2d34c26e59bfdf6e94fc349b701 1669186407000000 1669791207000000 1732863207000000 1827471207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-145 \\x3b19d2d1428347fd05e35c58ae3c3d4e0a7b2392ce38ef5c74ff8ae21947acbcc0ebbc7b1a72644fad6aa01b1fb89899b73d4beeeb8fd84ef419317d018ee23e 1 0 \\x000000010000000000800003a41fcaafa604b58a264d3cf2ed565d2ca56414bb29b624605ef8238d62a6a86373b51c6d9903f273ceb429a8409d47f43e34fad5975774ce7d2f837a38fb61090ab8e2052e0e75cec29131052cc5b5732b91f69e7a68ba216ca2ed4ec65b8a4c9c81914e66d43abec1ee58e6036fd3055c02b05d78274c7d422ee295e24f0c4f010001 \\x43957db5692d0497109c672cc1e2bca1a4f946f12a4a284ef13680cc3230619bbc07ddc48c83bfc08467cb31024329c5162876f7a15f77eb2cc8f19314935c00 1646819907000000 1647424707000000 1710496707000000 1805104707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-146 \\x3b0538514309afe7bcccb988cecfe1c20de1d80819fca633f4efd3e576f9a82f5c462263e2714c515857513710cc3ce10f0e15e475f8336039e2de19a7c92dd8 1 0 \\x000000010000000000800003db5710dc3151a4e70ea67e49193e56fb9ac723f99827f6be4f9079c96a5f8d68831cda5e1043b9abc92f97ec0fc7da904212d8c13e678cb3d4e580f6253ec5a47ad4988572eb1230b0bb2cd59e01d4cd43a9d75ef10b79cd1d152dbfaa22b5d6ba17d9cdc33a8f65d819cc38fc727d52998136b80bff6d9d9a06bc8594f7bcbd010001 \\x9f3715af2f3f60018e05b6e1bb3e9c5e9bb9b6e3d0a1f325e82cbd5f302ba1a3a93fead90f1bb4631885cde69dc802ebbdf2a844bb8e52ae29da73e3c72e9106 1669790907000000 1670395707000000 1733467707000000 1828075707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-147 \\x3c153d98df912ecc17335f02b6575ee9f142657b0fefadc6728c4cc44757d44922cdd2667241d0cf0f1ef569bccaff90426312a76840e56b3f3186d60d49ef5a 1 0 \\x000000010000000000800003ad77e0d4e733607704a6fb4385a5dd5a5cd9b40ae98f461ee476d1388b6c22bb204b77ca7aa91bcc94e8869d064072ca9b9d844ff4064fd147077a8a3e8eeb172ccb6c9a6f2ad4c9e035481acaa93eb62d7eab5499a5540aded04719de55ed9e1908517295394d5d9e8815ce3837fc2323b4545409548f118ea5c039abea6c3d010001 \\xddb35904559a095c7763d310ca49294c4586deadb00c63903e1c6b59ccdd35cf70212675f59a8e64442d41b06d1c32dab7de989cedf9f7bb3cfb33c484b1d00b 1669790907000000 1670395707000000 1733467707000000 1828075707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-148 \\x44fd941afa07c18df42f7989043111430ccc9ffa3826295b27269c4fe481f6f6cd5471956504fde2b2053f3a8b7b05ac2dcfb64191a4d7f89ebd42cbcba36800 1 0 \\x000000010000000000800003ebb0eff4cec291c93b6db5c710166525302d7a8b8392ab2c7c308888963c472085efec3fcca13f823a4c41c215cc76c3da7deaa79454b4568bdee58f052dfd004d10cf9915a90e282dd13396411d4ae6dd9cb0a4f4d037184c303419d266758a36854d8181fd3a5bf3ffa951162c3ff1da82c85066502ba80fc44818831bf4e7010001 \\xb9ef40cc8db5c8388d64a5f5d878ef4511037aed9d06c055de27f230de8d8bc3cf9d4f9f691c7aa42d1f09e28de97625fa70a32e99138000352c8cd238fdb50b 1647424407000000 1648029207000000 1711101207000000 1805709207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-149 \\x44812904b811f3a5e58148c07ca5b6d752e68b913ea803e42c5cc774e5ed1ecb88e19f1a3b7c8c37034f0bef7d5220034325836f6291803c8bb2d5f7355f8042 1 0 \\x000000010000000000800003c0f0b14e8f71607c8920d01553014f2d5e3660a1e94a4e550dd6c29b7840161c11d25857cb3ec355432698552864ef6cbf6e36bbde8923d0da057f478a62aecaf244ff795c23105dbb7b3790af9d32821644820f6f2464380ed358ada2fa58d17dc4b5c71178678fac9c04d5d9661349d7ed955b1050d1779fdfd6a62e6bccab010001 \\x1f4860762174caca2427325554de1ad6fe76a52928396a05280543db3c2460b31947bd35a50dd849a0389e16bbb166e6d6892da8af45a9ac2647b28fd15e6c0e 1652864907000000 1653469707000000 1716541707000000 1811149707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-150 \\x4ac14919e01b54f014aff517ec18f98c8d19f1ffa7a7305c8a7dc65fe0dfe13162fb6af7cc0c59a5eb53f737686e32adc5741fbef64825e02822f1577d57d41e 1 0 \\x000000010000000000800003a657b550da3a10fbae5dd729f5e4fc974dc5548cfafaa16982a26e5a2b6b6bba350e59e3096beb47e0bc69b1ff9174a5cebec9bfe38348ce4f3ed65bf70278514cbd244c65a92bd34fff2d6eb81969a7e23729421f657c2abeeb831bed23f99897e950e3477c92711d2fc03f38b6007b0fe44afcbae6fdea8871c9479fee815f010001 \\xae3b46d99dc3a629eac69651323839c4bd8e687271e0cf3440c8f47735c757116ff582a7ca42bc644f0ee6b7db0ed7620bbca07d81ac5b959bcc9205f4257605 1651051407000000 1651656207000000 1714728207000000 1809336207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-151 \\x4c1d539c7d10b99534846377a2f8185ca1ba74a924e522dc7e14c422abf6bfa7ca5ef28958cbcb9fb4029b46a6fd5f40372a7ba6ae756485b2a99d6911052a99 1 0 \\x000000010000000000800003ba1b32321db443b4632afdeb725c22e9ad686cd361f1c1b664981a4412ae0db787488867b8acb921c72eed12d2b2a84fa10fb3f6b460cbe672fcd3038abd8d4400b3acd4b11b8d08e563253693be68cde2e06c8c1df70d8c964afc4d324e805fed719db5eb99e478539fe084ed0deaa1ab7953de1d0e629b7a9bd387a2f33dbf010001 \\x7b32f7328b261ebdaa66040e07fe2f2979f63ee662a9686a2e958c3c0c912bbd23ea3c7c1da97121e51382f7c43c80e63c4fa4cc9f9029fffe34350ba3f54304 1657700907000000 1658305707000000 1721377707000000 1815985707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-152 \\x537975678597678314da43fc3dfbe27cdfbc2642e8361a150d35a0c3d5b80883e3520a8295c51c6a9f997ca58957164e38e43a1c7d6ba850ab5609b0856e00d7 1 0 \\x000000010000000000800003d216eacd09b957220d6af41d1c4be5285cad3dc3c64c632bff9704027d430a95726b3655fadc0e9a83ccc2bf32e0006712938ba0c37c76344b8dce1534347a76f38adff15e8e9a7be143cd5ac4abe1209faa19f0e29ae3990647373742a04621ef4b425e0cd300eec3339f3019fa31b82cacba95ac93bb62f0ae3f9d4dc1f89d010001 \\xb9f940460a3ce2936a03c322f4a5045592fbf3de97988f72d581e1c4865d0037854fcd9c89f0f84047dc8f8383d6d797014a6463bf1f0f88ef43e1874c9be20f 1654678407000000 1655283207000000 1718355207000000 1812963207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-153 \\x56858ce35bfdbf6f7be5a299ee079dc75f4e50d684b0c979d2d3912b1bcb92d8f7039196f30d64741769d0e3e8a04c698218412d0093c18b2e60b376e35c598b 1 0 \\x000000010000000000800003e3879ebe3387a2a66c480b2efb26c3185fa488cc6880aa3748b1ac071309ab897de16ba14ac7ef3b1a34ebc7431bb2b45cc8b30a14ba744175e6a090d9bf0176cc2ad8ed504504dbe4c7001a123e4ad0697be436827ff8ed9ec52f6c1799907247ae5be23fc4bc41b5c745b81ddd754fd4adbb7a3ff38bcb5321b6beb159e993010001 \\xa01f5d84c67573ebc1570a0b551e0657b61cd45e928bc02e4352c875ead571d04d5ca0638e4efecc3ec7211721f86b92bec94f36e920dd48f62b427a2afe090a 1668581907000000 1669186707000000 1732258707000000 1826866707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-154 \\x5755ef2eeb0340832e5a47adbeafe519c3ab59420207a710249a2c800ac8f2d5fa64221237c960b43001b614d7e0152225970a29f729602473e99a8840f1a40d 1 0 \\x000000010000000000800003bcf1fef5ed05fd1ad804066ac45e276b32d859ff28fced9b24cac6aa82917dbf1948108740fcc5106f63b59a27ddbc6ff92c7b8e1bd96f754c216c1a3255fc46c378eb2004ae76f7955bf800eafef2c9c5d483a03d80fc1eef21105e08911b363771bb303b7d83960b17f6490ba3cf48c44ffbfa9aff430015ed3647affaba6f010001 \\xe3c6665c78f7e5abbb9dc1050d85a9bb684989ff4df855766924c536ec6802cb76c95d69bf201ad8e2d4998a484a7134f9701071edb43f5c186e8bbfaf00be0f 1662536907000000 1663141707000000 1726213707000000 1820821707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-155 \\x588931b9d0d2c7eeb96e9e597d0da5642a9b300e2d32cce8d6cdaf6f835f6f4460772e67c214fb85ae658d79d4ded7dc5a3a6f8b94772b926f6db6db903b7160 1 0 \\x000000010000000000800003cb16fad8b255abf924afac96190e9320f1a8af3c9f72bdbc77f6cccbe593b90b5324ac70551ce0d98d20d81e3a6e5f3b3141476bfb213dd305eb43e394f5ffe95d3085fa69e94aac63c113ca01181e1138a001574f9eadf4dedc0afe15613ab5c493a6a99ee92ff09df681b0939445d506e48e34747adb58f75789e27a5d7247010001 \\x7fdeade2c24e8ec82ce37d519339decc2679c35e312679fc64066b3d1c1eaeaca6695c4dd60f141127838f978824c5f58cf2e64715d17e88b038a93e5116440f 1638356907000000 1638961707000000 1702033707000000 1796641707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-156 \\x623d228eebb27aaf940fcce68ef85081ccd0697c8e3ab3f0e367957ad9a00fb80b39e27894e3acf496772e278cfc6f114b2163f2ec843062c69d9b20d1d4d285 1 0 \\x000000010000000000800003c690f8b9629b8ea065e9aeacca17233cdf7a327b6960ae7141c196af68db87df87589373a93b971a7e0b304c6d0409e9f06b94ae88628b1ff198d96a448c6ab1d8652eb19388e11043619ee3621a77fc6ab5f0426ca50dd49e19f45d6b35cf0cc9dba41c52d7abbb5464c8e18da68c8017f7ee4c04f5a40dc24acc1afeddf2d1010001 \\xe9540fe34e30aa38232fdd504a02057ee9535b590fd937cf3d98c57d6dd059d133bd23e17ea62c34cc88eda675d0e005e15f4012a99b33a64334fb706116af07 1651051407000000 1651656207000000 1714728207000000 1809336207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-157 \\x6309a1bd9a269a819a9531343d1be703e84b9ad2ab9c7840f1bb77616ddb502026b88ce44722ae1782463a3e1246c3a91d4074ed32fda54ff4cc2a850bd777b8 1 0 \\x000000010000000000800003cc92c4f4f8bf70cdc9e6f237a48af057f6d4b597a07e340a1c4beb2ca6a42672b492e15fc3724b1a6d65337253a6db7d2c690384aebd6542b8d0d3505e97815f11afc0c3c42096013cafee596058e05649270aba53f7697eac0e9cb8367bc65f569bd56159ef64dd30606ed5b432bbd13ef5e1cb5ad1f7a0d53c104acdb3205b010001 \\x6a935a9ec43660023349dd4985cc39a4dfdf4114531ae3f2ef1d88aca316b8600dec8a54379ff468789b7b4e20cb70f412a90aac96bbbc6d59e06a97863cce0c 1649237907000000 1649842707000000 1712914707000000 1807522707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-158 \\x63c58c60a12fa1c505e176ef6e5caf55f66ac2bb1323682ce57b5a050c9605b9f6b38a8e1efcfff5c35e2d3651cd930d2aaa016c51592a47e6c7fcc296e4e102 1 0 \\x000000010000000000800003c5408cdb91dafba446646d1e9c535c62449d92aace1bb0f16b1ed2ee17a97d68716d172e075fab13f912d95108bff287e704a6490deb79b766536c9c45dab40219dca7853bc1597610ef5508e221d383a07af025dae469e94923da72f104ef524629d472bef46d3604453d7b7a156265464868830d303d45373d007fdf650bb1010001 \\xacbd18d2f99aa485a97e811cf7f210cc749132398b6c88ad7f49d994d703a3a4bf346c902a26672a53145be43382a2dc8d530f4a6235a4b4d27528921c2f2e04 1638356907000000 1638961707000000 1702033707000000 1796641707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-159 \\x63a56d745ae4f2a8741729d7d88e7ba71ebfd096827b4a855fbb7632e5d0da8be78b19bb297bba225fe08692aa4470dc1d66e7cfd01f72c4e982bf93b452d454 1 0 \\x000000010000000000800003a73c31de8a0cafb15ccf2531af5be4af67ff64dfc0022aaf1b39522e6429dbad4383b1029c1231bdc07d8b69f7bdaa01dc4a8ceed531aa18ad64d1abcd236d0a31aebe9b9eacc0ec50861f7d55097be84f22318b20a6abd5340757f8ecb4d8e9fce9dd625cd4fe682cbf741af8b88af2a568b1045bb7438684e03b82e44f7bd1010001 \\x4737aa50d13d5a15e6a7a2451c344443336b45a6c845a871f1f050942e1b1f312a845e4173d1070fdfc0cb3a1ed5decab1ab496bb929b46486bdf30cf81a7c04 1666163907000000 1666768707000000 1729840707000000 1824448707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-160 \\x6b49467955395d31cff84faf97a31157067b9ced45855d9a31c6741b025e65b60b126457bc18c08ac0681ccf0269e9265ced4131c7ce8807fd182c451ba8673a 1 0 \\x000000010000000000800003bb10ede28124101ec08c09d1a20092608b8142bbec7b046362918e76ff97182ec9275cec0c9819b7e7edca59465396b3a2a71c08a4d44aff84720ad5b5789b532b9e74e8be86e7d1a731f23cf602a073c5ca30672e53dfa5971f4f85c1db1dd65b0164cc60dba4734fd66452a4a1e39cc40035699d94c9ddf79c6f57ee2c064d010001 \\x168db54f481d831aaa096d7d04e47d2fb2270d91fcc557845e5b61323a04741e3a2c686d2a0a40b1a676973f9bf9a772eb1fc0cd5cf2fa895a76060584b25300 1639565907000000 1640170707000000 1703242707000000 1797850707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-161 \\x70118c39152088cad055ff26947fa187daf522b244d776b990c70395aa38633f192dd86c18071d0746fadabed4783f15ee854f60f37b89de579c85a4f1be650e 1 0 \\x000000010000000000800003c17e8f321c627b2d35c5c138f486865aeea075741e0d5d8c218bb4dce7c84716c2de15c79e8d4d5e9152db41a94fabefcff0e1aca52f4bee859cc07d8b49445c639cfaf25dbb97b61fba6f70a3c28de7b1c498d13a9b5f34b76f361845809917538a188ea7965d2e55a0e1b460d3d125310bb0f45bc8e9102c048a84ad80d4f1010001 \\x932c75d56d5772d41bd0e93efbe1b8588f94854c15b4154d7cc4c5708c413ba145d2aaa1531654bab56f088e03baac710d66607c5bf24fcc3f483c9eb184b708 1647424407000000 1648029207000000 1711101207000000 1805709207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-162 \\x70955d8e35de31943b19b675fa22ea8c0f262584795ffcd7e08856dbe7f4960c7944dd48337c5190cbb1f1681387ed76a3a28cf8e1ebf701b49b8956e17ccb2b 1 0 \\x000000010000000000800003cb15df4d27c9501339d05f63acbd9449fbf87139942ad26dcfa93415a82b41e72a138be180558b75915d20bb628604f7c3d04ba259d2a1eb2b724f17bff09570de9392455e8e63138a22edc611b57dace00a039f5305e4367787af31faabdc7cb3bf603690555bfa6c338c543753c4d750b29065fbd0ccce709030f3d842605d010001 \\x1b4ae8ba9c26c206cba1d42eda2a645903ca140b3429fc819b5c22b22d4c6dbe5792372c2e65b80ea83e3da9ff2ead1f999cca872ba33968f99d32989be3ca03 1647424407000000 1648029207000000 1711101207000000 1805709207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-163 \\x722571c9cbd8dc3502514ace085450fa2da2b7129962f64989eb39a42e92845996afdfb9d32c76f2a1c635bae2fdd4c6089338a543b807da8de921fbb9c93877 1 0 \\x000000010000000000800003d715e14d5041b3da077b26b6aa3db33a6897dd44ad5c13d6d1894f0b26fc1553aca40ddc3c268cbb390ee6a2d6c38d95e13c9412b2694f47fbee2a71c7cc15e558836a4e93d899af7625566c428a0eb074bcfea07ebb19120df3f185534cca55e7fb56467f0acb853b2bb8265bb89020cb160145fcc5f57e15373adfd579f6f1010001 \\x08be0c1caea01eb881df9c91e58e33fd409310d0a73b00e4af01635cd674c68abd122cb21d4f33de06d089b4d4713edb33b6a99ae1f7aeb567605a39159ed409 1654073907000000 1654678707000000 1717750707000000 1812358707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-164 \\x7339addc26f212ddce9a3d4df9468e6364965c445b53438f9aa42dcaf3f7b48928b012aeaec7d4d81ebf48730d06cd0465faa6b01919b5606fdb03650cb02ff8 1 0 \\x000000010000000000800003c5f92023eddcf9c4504f8e1ebd13b0f268415ca4a483b1e3978699fc9fa2ccb833692a2e6216cf53a922316342eca35526480691318cb66c96f19d087974a370351994753dfbfd322cf10511c18805893de7dc8b16b838fe4bfa242240ca4d31235375d21581f42a4537dd260327b947b76c00ba9782ad786f51e09a4ecd5827010001 \\xefb0c00a1ae75f2f12b80ad008b07dd1c6bb870541f7af2883efaaa6a8b92a5baa90fdcbd723cb2b48b28c087cbedab8e1ed95982cc833daba3c5f14b4a10e00 1667372907000000 1667977707000000 1731049707000000 1825657707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-165 \\x75492fcb5acfbc10ca2f997b9ed8f196515cc27aec4270dc97f372bd6acc53e8575863be0874f9f9901b90e4dd99a05c250c112bd2b779ff1fb8293bac2f7a9f 1 0 \\x000000010000000000800003d8ee166a4b8769de3fe1277729f24ef75208951ea1164e9dee5af94f67c053dc0007b505232388f19c838ebe068a8e66f8b3812833b97fc8eb71c79b2d0bc76e2e5722c38c2c8053bc3d728e3052f425e543e1e3737e42fc0d5174d251fc4087db3fa32cbf8ef3b83b96449bdb5d4cabde32f283174cd5c947eb8610689166e1010001 \\x7c45a1d1b30c7442c8432f14a09f0cd95c2a5cc0b4e2f847f0e5852a2362e4b4748a96ebfaba9c7c25dd1525a1fdbd65944300f8eb18a288abc1024553078d06 1650446907000000 1651051707000000 1714123707000000 1808731707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-166 \\x770d9aa768bb1da2421e8b1bf2aa3591f3a7aa312b97db7dad4e4daefd71ed7a5c4d9a882617596743de02a79890e5f4d7889d627f07ee667655665562af0a49 1 0 \\x000000010000000000800003c3e4e3d0e820a8ccd44fac95ba8bb4745ed947e6049ea78f9620362ddfede77b4843f4bff12a4c74d7af518cdf82296db585ddfb342e69208d0a7ee8a0d2a8ad7c69aafa444a3f610c7129f23dae75bab5ed4573dad71569ba248aeac4e27806626daa324fbb206c42b890718116997e7050ea82040201318287d328d089e443010001 \\x8d49f906bc900cda51e417dc75b111f173a06718d02fea68367b9e2395afdc808cabd0293010a7a697b2aa113fa3d8afc9764e1aba8c051887475f09d2220a0a 1664954907000000 1665559707000000 1728631707000000 1823239707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-167 \\x7701de84114b0ddb781293d93bee7d7d329f6ed2cc8efb0e02458a811604b7f9b039185765613fdfb7d4bdf759c1afd6ae41b12cba1f3d9e3550c6b2696ecc23 1 0 \\x000000010000000000800003b78e3c17eb31d21158f28f2912174b8ee50a708fb4ed9741aa33ae8ebe2a787858cffa1db937f7a255c18a3f1db8f6410dfb5b137ecae00bfb33ead3ef691a17eaf1b67ed60780ce3be567ca7d475071a94087fdf8fb527cd12b021587af7057692c3fff76281bb459c50d2787dfa726b4da02e4af8a37a89b96d2b30975ad27010001 \\x0db5d90c3c39645c39fdcb8e65b7fef91e7f9b29fc3aa5e10512b2657bc602cd1aa7233acb35d5bb46d46444b389e76899513438701d66c1d5913fc77e6c9a0c 1640774907000000 1641379707000000 1704451707000000 1799059707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-168 \\x777136e6dfc8636ef4c597226540b50e19a61fbe86dce64d516c09588e9ec291b75939eef02cfc13810bfceb3818b5b829f289bda18008f8924132b310ca3d20 1 0 \\x000000010000000000800003ca7ac963b29fa6766d5a3a3163b51cda4c87d216ea2d5eee6108d5519a470246e8ac9a2ed3384f7894cb18cf001dd282b1addf6bcd6b910bf3a031a4dad3bb813b8b11f3e9504b0c89e63d47441e7ffe4b7d6047db23234834cd2a794205afd901a82e19c487c72c68cce6f49417a34e7cda46bec3b595c516b4e01a795bbf9d010001 \\xb569a74fb512309f5a034f5e4f40299bc484d0575397560ebfbe2085ce66752a8404d2740e245efdbde2d194b4ab2a71e625a43010a569054160e5c0b6626807 1640170407000000 1640775207000000 1703847207000000 1798455207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-169 \\x780dd53e4c43ef8e74f4e6e62009e3588538f72774e8a45bf484315af12816275769659ca62341d1ddb687fc71c8e77973947a1d5f1774aa1ca6840e0f754ff8 1 0 \\x000000010000000000800003bcd405b746343e4515ead0d7265ba5f5b68fffe618555ed668a175da33190b0a4fd5106a946ebf33ac19c8892e0f8bd2502f1989c77b4d995241cf6604cef45ec10970961cebd5bed9d822becb4b0fc68593c424e23f67c89103ddcc347609f409a34b82417f581b62dcfac9f1709f6d979a24c6fda9b070b165f3c7732b4209010001 \\x0477edba16b630180a3b57c292319d6da3ce0407cd41a409d81c2012eddc4e3a19471d998bf6bd55cea935b330da3eccebd27631d257f7e281f8065c21b9b20b 1669186407000000 1669791207000000 1732863207000000 1827471207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-170 \\x785d64eef1faa396b2525097432e98ec6f38f838fc7ce7f4e8152bf3b43ef0c41cb12cd797427c0fef8b1e9513fd86b8a8535fa26e262c2801823c286d9c5c02 1 0 \\x000000010000000000800003cbea7f6269a2b64434ed74d9d9604b58a637a1c403dbbfef1f0d015c6472f5bf4f102bc189557a02ffa99995687e0e8b5a04efced17abd4d00fe2f9f7527f10da079df4361cf0387ac4c09753796ab4ead27397f65a438816d912abf308fb8399d0faf4356cf468973a2e60bb593e4414fb80c1986583f96b2e090e0d82c0851010001 \\xdd4aa74e7a35f888df5ef46e53440c78d61fb31b3265be7db635e386bb52628928adb7baff4069b1cee2fd4e7aacd5e70acf3e3b8fb40494448bf2426a069f04 1664954907000000 1665559707000000 1728631707000000 1823239707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-171 \\x7949be9e088e1caec150c831cdee65cea98e316c23f8407063a86496c1c8579064798c98a23ab86e3cb83d05da5f8f07d89e88d3ce747c12b066ea0fff2a10b2 1 0 \\x000000010000000000800003b4a54ef9019dd8027b51620a786b256a7fc3b57b17ac026ab1eaf75c347cf42c6b7dd1ba17d1043ac9d1000ba866f8ece8068d2d456e930ad6dd0ea7267635e23b98513111614f64fee22c897473020c5e09d62bcbec22cb72719ab640782dd517ad45d0adebabb04f896548f972c97e477fe9aef328ecd74d6ecb7070e005f7010001 \\xab21068c3f8b2a322575a0d044b61bf8526723dfded50663cd3423305a25107400d50bd31d61b6da6b4a277f293d8523b5bb7e084fbbc9e61957c3d6f1afa401 1642588407000000 1643193207000000 1706265207000000 1800873207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-172 \\x7bd913fcfb61f685347f44859392a30772971149abf1ddf0b14fd84c0fe59485acac0b83199fa89b938d4239d649f37015277d1d04db222f582b28341c27d5da 1 0 \\x000000010000000000800003c68b4483cc0cbb9f299af1a381aa994ded584db0ea24f97c963767384dccdfd03a2756f58cf40341f5c4d7c22e8f567e7e4b4ee5bfd719f47ba6db6efa354689297cdf3dee010135af157cb7cc9547051a79a6cd6fba6096196d0724e0ba9540b2859906253d45c866ca31e178478a8bddec3fbb4fa54de1b8e775e24b8f3fc9010001 \\x94e3cbcc79a6e7d05a26854f97d05651edc5a87b2047889c0907cf65d9dbe01539976ba86760c26f2e0396e8d01c4f97793c148547272a31455299866f306a05 1650446907000000 1651051707000000 1714123707000000 1808731707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-173 \\x7f4d7e6ad484ef0ebac7b8a34b58a020d143bfcc2114f1c67c1631f86cc48e7bbe81872e0b0d5536a1ac5605eea5256d4b9c42b186f2a96308060a1a8c576144 1 0 \\x000000010000000000800003d5eb011c8c2b3f883a57cfcf9a15807b4dcd96d89293833a985fb51d3689c790663e0c1391dbd4462ab3a09e8359aa5e2a1311dd3edfdc8fe5492d7e5ff710e2cbf96dc6c6e500ecd42b7d0c778f6fc0bec354e6d39c5de7ac0d9a8ebecf1d04a9b5759150ff33cea36b4694d2dd7fef65a862f71fd348a290e13b82b2f47293010001 \\xbb1a96e6aeef7883fe4a7edcc73e5cf90a1d6ff9cae296c130c5d4438c5b1f8d644422f6f3831cdb44341aa4cfefa7f0e2ab72db4a306494711583d8fc1d0d06 1654073907000000 1654678707000000 1717750707000000 1812358707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-174 \\x7f75dba5d780d2e4fed7f56693b8344b5ad885b9a7d8ed4b27af6c9e666926e5bba876f928d55e10d03e306caf6bc148bf4a23c3682b3aeae3357886efa74a81 1 0 \\x000000010000000000800003c98b1eacb09209c4aa1256cdcb6ee416ed0423c35ec1673bdc98016d5ffce1cecfaed920e679624001fce32c6a574d0ad158c3ce15b3192ce41029c83564527f1c1fe05775b516d60819b0ffd7943a092eb0db1fe80666398c271c4135cc98d1ceb4e58da44b340cefcea3d4a7754e198c4aa4c458d6b0109648841ba0d8d5e1010001 \\xcc01eba84a6dbdce0dbc457f28d2b7cd0657cdc48f82c09da625b1856fd5f38329ac394ef30341a6aeffb5484130d7f8718380b6aec316adc063fab9e407c50f 1664954907000000 1665559707000000 1728631707000000 1823239707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-175 \\x7fc9bf5940074bdf7a52544868f909fa71bc0956414d5737f556a03c933453c6a7721d3aa0f29a3d8cd95e39670522fa3179d1c282f67bb920a94ec3d98c8b2e 1 0 \\x000000010000000000800003b08c3b4b175fd51a991c927722187d5fad0d362ab1653d5ab1de7cdc67abada9f033707f60fd21ee9faa093101aed75678044246ac4a935dcbaa66f9733269af53983b3de4bdf4c04f97d3f556fe7ebb0c6218696fb2644c16f559344899f0ac6b4a2115daffa29822c481b6003657472b0c08ba3dda2913a7fd0cb8c5e1f19f010001 \\x855986ee3b06375677259f9f6c6974c9b335b2ec94f929de2a2a771f0c02b019652670754c98169fb047fc7866ea956c77f502dc8a46c1baed3e7b966c79210e 1641983907000000 1642588707000000 1705660707000000 1800268707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-176 \\x83ad663dd2d4d8eac1936b456a96daff27bce3d30174b392a9afc1bf41dc79c9175aa5f330bb9719e64247f87ae938b00c5aca649555c06be3efa5115b790bce 1 0 \\x000000010000000000800003bda8d919008545b3bfa90f09693178ffaec7ad1976cb8aeb3446b231b8926caf5b2ef4341cb70bd257694c4c8938cbb9785f0ffa3eee071172339c1058ecf4bab21f74315c6392764176c7799a472b875ab3048dc4f9afe1bcd3ec3cfd52e6529e0e199076ceffe31b4bfb0e45972569951fdc35e6108a170939cd0bcaaaa7d7010001 \\xd54c226b036287a5872f470a29f54ecc99d1a222ef7cb27e081f45824567676304502d5102f92f366881ce1159c5f3c4849611c7e230f35a5b61cba994be3206 1660723407000000 1661328207000000 1724400207000000 1819008207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-177 \\x86e1795db0e3af41bc2c37e6fc03e7acc52a65d39fd7d4860654832133898dfd0de50bfc576b4adf815e36b4c0093042c7948a31610befed91583cd6d19e37c4 1 0 \\x000000010000000000800003c8fba1c15353d4686cc54649d31e04d429d20b69161c5c13e1cdd057a12170e181af31b4879f6ae9e3dd5eb4ceee1b7c1334f54a1bc8accb07d1c8d09938e0fd069722078f2cdab8d51b93378b491f10a800b07a6500b5403b7c23f975b469f038106cf3a4e2420b60e1384a0f46649ceb45f87585cc4ef65bb320250ee03ca7010001 \\xbd2d6d5d5a4d245061d693a08028079c194084e5c21fd2e58fa638cc94dea962c8b233779ab7220a52d3ae106d9522d78cfd1bfb23ad489bbf7f8b13a3b06f07 1651655907000000 1652260707000000 1715332707000000 1809940707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-178 \\x8649c33cfc3d0a47f086ffd0cf7cb5afffe0e77a82c0c12cf24b0b5ba6f181aa38628501cb9b54823d8d7adef2c5bb21abc467a462cd113c04f58cc19178fe90 1 0 \\x000000010000000000800003bc1c78d1be04f6c39438d229529890263631c8e786998a41473443854d633dc4a2b84829351019902ee5799195c6aa2da71a214339a7f27d2a65b409e25a1530c71bf34825f3bc7363cd166c023a5872929407ea83bd4713f38931caa22fe4aee3c953aaa9245f2b5170f4706a4ad8cc323693af22303338cfd53bac6aab07e5010001 \\xdb5dc152d102bf1071a301d7ecdba68ce7142a7a2c6e5367fea735b24f8010fcdfa8b28d691efcfb81e031ee2b8414ac0f15e88c1de3b4e00898a70710164e09 1663141407000000 1663746207000000 1726818207000000 1821426207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-179 \\x87bd9a29d5f416973725824f7ef209856bb17ff658c71efcc1edcd08455b2f6900139e13a8acf506944a405df42e719d707b2ffaf9199aa888055b6cc144c519 1 0 \\x000000010000000000800003c053a49a2429a5abf1e462856e2632e7a1124c49a82dc0074e60edca25ed18d5c7497fb12c54deaf2b0fc6e28474f066e3c4b8b927293025091f200a0d5039f988cd2216693d75a24a941e5cb464b22d7042a47c5e3c3a09addc8ee363e53f905be497465fb5097fd10e2b3552166d984bc8018518cda17c748cd537caaa8319010001 \\x44b76c2c0e6a2187c2b845948e87532c3a627c9f8fb8e45770b9b634e7aec38d7277962b8c5f9c19d00c37dcae11072f16e719c5b83ac5e7054deb7bb605c200 1641379407000000 1641984207000000 1705056207000000 1799664207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-180 \\x884da637a3db48c4113230ef65b075d2d6e567dc1e2ab342686807e96efa122bff68f2b3547632197a121cfc0e98af407ffd9eaccf0ed82dc227245d489ea273 1 0 \\x000000010000000000800003c29b0d39de7314f9ed366f188e0857fc8d8d97212904bafc65447685189ca760dc9a7861ab114f45ec76d5d4cfc1c750797007d6e2428d6c2c57c5f98e003718bbc1990a6108b68f3b52d3b93227775eae616dd91751f51a8c1d5ffa3643032e81e0f18fb56678abf9dd99b365f1702067d192cc0ed7cfdd54646a1c776fe8d9010001 \\xde9ca5267a51949b95d19e369a125eb6353b5996e90d3353502eac8f4501f303312d7bb0788e703dbb80ad1caee9b866b6d8b355586d9d549110fd6b4dcd1f0e 1639565907000000 1640170707000000 1703242707000000 1797850707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-181 \\x8cb1fc2e1b3c6dda066a4d7be334a40508d2bd37b913e6fc134d2491abeb85a9f5f0e5a9012e9627af79b3a04d878aee14a35be29df80a781460ac625b6b2543 1 0 \\x000000010000000000800003e06dede90d259f9ca753fc963a67042fd3ac7009047af80d883884ba1a8223e12c36dd4e4ddae06575f9830a2bf7ba3ca56544fd26c7d8725fc3e2e597204ea416631d3175a0f6256a3a759487a7c5087461c495326ae1898f8b423e4feb7995ff08aeda248a875f6a3b2e084f5d5624178241ff9066ead72095774148fa4e7b010001 \\x84a82e70f26d13770990c138d9ede53c3f3314396fa23b11afba1b849a04e4db40e67f679f0243c4fdee56e2659ba3fe11700b02d642e29567571a9e0b435608 1645610907000000 1646215707000000 1709287707000000 1803895707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-182 \\x8ec92840dd0b7da113b1bf4afe8651ec90df09705c8d617b1eaa066829fcfba106ab7b4af2c187efdb9f51d64f1e886be135c1dcbb4bdef0bacd15d1b33f16b4 1 0 \\x000000010000000000800003e45134432b9f065f415f1c51154899a28e85916362662d688b14ac7e2264ca4a639a49f61d77a888b3cda81dd5c17666365cf9f6cdb55baf5262eb787ae2964ffa39e820529a96e517de0b9f40969c17f6caba5885e9befce9fe90004e7cfcc6f2fc464f93914ba2fc285868591dc828cca0bd33afb36d04b15fd7c32c524c85010001 \\x5aca22c46bcbaab38bf633cbabda05f8bf719f8474749edeb50472f9236b39067c2eec9a92340d1e129c513054de85413436cbd79512d7b008248c1180a0be0f 1661327907000000 1661932707000000 1725004707000000 1819612707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-183 \\x9451c52d45b48509e39bd81374c5557744d5f403c5e13a6bba191a0076e266f5396dcc8b59c6b9e040e6be598946741b84d5d4e98b9c819d1962543b9c45ed34 1 0 \\x000000010000000000800003ba221906e64a2ccab89b004de7e1e3cdb29493ceeeb9f54694552b14ac2b5fbaf82383d01aeb0261128bd8c23ae978f386b69a6ea2a1d76ef3679b9757352e30529b0eaa99fd1890adf8109605032dd5002923c4502926148e2c4a7971eb5709913aa1488dcbc184d60989c3252c72b030c672edeee1fcad084967780b3f054f010001 \\x78e834aa62f8f14283106b7d6c0178f7b0fd197e389874a77a08b6dff620849bdc5ed1e97b5fc13d01e944d68199d88f0aae2662cf54b9763769fdf099f3f805 1661932407000000 1662537207000000 1725609207000000 1820217207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-184 \\x9569ba34f046cad06ec35f74e0a960cda3c0943dcba873672bba2dea4986efb0b277d8f4487ec68d6e3faae11a93b6fa09af5762b8cdb0bf63b4c8956c946e3d 1 0 \\x000000010000000000800003a6a75f534bc5e36d034d84eac3820b76d8b2f1de3f8810456b270594a48b4032bbc5bbce0d36e9650c39e1ffb9d1a006560afd082d464b6039336da73d0a193b40ef239daf8f411974cb905bee3aa1dfad6a4c4c6bf2311ec1a398412357493c304bac455c5612a04b6dd1fcaf594918c0b901eb1dae97c53b0c6d23914db3f9010001 \\xba6f7fdf9cf45e75240c33de2dd18c45f2e144e1c402037bcecd30c98182506b1ce1b8b9c045b919747a1b903266d4ab66cb215c84044f6d2307b7d9145d7d01 1667977407000000 1668582207000000 1731654207000000 1826262207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-185 \\x9961f49a0ab4f26dc567d883930f9ee1d1e46d71e423aca7920674ec2be3e16d348a9fa0bc69ed700bf710483dc6faf58595bdc73dbfb60a261d88a2c0462119 1 0 \\x000000010000000000800003c792c93d77262aa3e2e3bc8facf6b8a1e67b2ad5f0ae32f40855b6f8aeb0b29ce21679cd675d062ed6c2467e39abb240758ba93a5c3f973de7b13b05822c91e3e089fe49a5732077803df607d6931ed307498de3d390c9dfb17b9bb2eda57a478e9912f16a34abdf4bb184e19a7d6f93cca491c3a4c4645de3b4918ad66d57bb010001 \\x47825a1fdd1081af41f356e2aa0e301df8c9824464214363f8bcaca565b0cc14f4241e23a6de02bd87e87adcb2e7b16601e2214abe87c2202cab80f06d0f4601 1663141407000000 1663746207000000 1726818207000000 1821426207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-186 \\x9b8db333229285b761c269bd75cf4b94caf8a134bd72ba33d8afb4d13704d8e1168339bbd3b199c04917d2b38c652d0d32403269c0fc3cd1760bd29a6b0edb75 1 0 \\x000000010000000000800003c4bce8e6acf6c0e941cb4a7f82e62b240e62d9f9487f7da14b3b5775fed139fdba54338702b15fb2c97727a04947cc2a4e17d1eec82c53cf3f794fbcc4756eed8fdecbe0ff1f811e0e1abaf6f58770761d8f38f0a0dc32fdc80fae61f6fbb6f6f6315e15585c04b3807373b04bcd8ecb7dc51bc43760f216815ab416313cd4b7010001 \\xd1deea13941ba31da3c224c673dd98d048be61fd223fc827388dab1cea1026665ff86cdad5154cb38f55c349cfcdae6ffbff7f04bf1ca732ff0df8c3a4e4d00f 1661327907000000 1661932707000000 1725004707000000 1819612707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-187 \\xa0096bb1371ae97b911965dcb4b1b03080b96e95fd85a187ba8c796aa9a0ef7ebdd89f3d54b374fef4827daa229d26cce958ac625db60302a1437d5df8ed260b 1 0 \\x000000010000000000800003b8785d8aabc06554ce231ee933037b64138911ef6727365799d5f5051b4556f0ba62f62daf3940c7e7857cb921a2b483343c969980fc9ba16af6c7a438d2627461c20e29c3da5c4f44d0e80f7126681ceefec184a1f0477671b8b43bbb7d7ef1a76d2b6de3a39194ce954c03c2b9ba3be2642e9a90e7fcebad27f1555cdee84d010001 \\x9994d80ec769e62e11c8b3af0ffa3edeb6a9fd8c84bec47a5d591068d380283520d7b2125b5f0c4512245b77d2e443437bff06326f371a471293beb8d4edbd07 1660118907000000 1660723707000000 1723795707000000 1818403707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-188 \\xa25540f0a493a3054260c56ead265f0b492df98323e24bea67b01f59e72215f90f0fbe81230df0ccc8dab02ff553f11583cba835036caaebcf19bbf96438021b 1 0 \\x000000010000000000800003af85469b40f9b98e338bacd750aba83657a8b09fdd19bd6214cd26d5da89253535862041c6f4c256c225a21420d1ba438bacc43756358f6d763c088d527334cc0ccc0fc7b88278bc19a518f54b97b260ada2b30e5351acdcc762c851c6730f7a0488af2c7d975eb8a67ba960635ec6d15f58a26279ddf3bc41a688a0050bd693010001 \\x221eee7c967fe7c18c47dddbc785add42220d25c605d05d88a5393508b241eadc2ad31ea5a9b38f6e104b83ba828273f4f9a29d10fe6efb31b595c0b8457f60e 1662536907000000 1663141707000000 1726213707000000 1820821707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-189 \\xa91929be7a78f0b313a34983c7c0f5ab271830f850467e5c8926c89bc53ff41976c2acc0d6f8f11ab08d35f04675033e027736d7655399e0945fae35226283a4 1 0 \\x000000010000000000800003d8e51528ce6d4dd17178ef49cea6148e9d9fa26a979db8eec6d1c4607c44ccb99051d9d3e5f1c2e50021393bc1942ba114c864c1063fc6c069aed16fa0eed5b052d576839d8cddde00982a61e60894700ce9c5cc4ea965190b9368722d3f69f4d47025538e139e6d4d9be40946acb48b11a45eec16faef10b0d8c49e2c17b7df010001 \\xe8ca6795361dc9055d85b538558a2db1b05e6a137cce3325cd0af4aa4a997f46136bd90799ea3610ae29b4ea789287562f96524064390df27cafe964576b0907 1646215407000000 1646820207000000 1709892207000000 1804500207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-190 \\xac9935d79fe1115e173b3ee01063b07be455f89597330783ddfc91f7479fe5358eefebe24c91efe61a15137b5bc3a6e465c5d4d2ae967eb3c9b3b49e1fd4695e 1 0 \\x000000010000000000800003b3a23d70c4420a70b87024eca9cb0b119a4c54628361a85240366d7542cff4907ca05edc32243805f3439b794a5f62f41bae82973fa113d732d8be7623489334e0a2c56693f036a7bc0f96baac08f90f5a51d5db9d623b848cb7a11c2e53b0083037d2f9ecf9b990ad223ab3ad28fef8ae90a57e18675ca8ba7654b865309199010001 \\x129f6e0e8bb2640fbe051892eda82748fbdc2bd1b9d855b4f5efe95727b226f85bcc1cca1fdd8a4cc64fac8c2c627f8780cc3a29109f3bdfb70de2aca6e2e906 1658909907000000 1659514707000000 1722586707000000 1817194707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-191 \\xad01ac8e902b74e7c83a43ce5f87130b7a18e265eb89ce612c6f60ede4ec07f699fef60f1f02674ca1bf4c2c6c159ef4cf42f3fc1c3f1a72128ca3d477448ebd 1 0 \\x000000010000000000800003c588303a95ab215e828b00464ca52dd273ec85d2cd62935dacd03ee706738fadf376ade3179f1619dc2a5000046bccb7e044518c53a22c3175fd43354e25f311b86ef4c47c4098cb155221f64b06dec6b94cd03ed7d60fba73803a023f8b98f0051c25cd97cdaec4e17cb93194b0821439c1f99f8151e8c7ac0711edaff91b8d010001 \\xf45f1be18dc62d9fc176d48278698cbf62002ddc0da1899e52ba403ff00c57bc914d1a29d869f348af003c71350bb18560e559305c5c42364e15d26a7fa8350b 1645610907000000 1646215707000000 1709287707000000 1803895707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-192 \\xb1eda56df8407fb48bcfc817ad0ce523d8c8455e13580b232a616655da731e12cb2287317667f4e86ca50001e0c3b14b68fc668d5769864734c33f8d364925bf 1 0 \\x000000010000000000800003bad25ddda31cdae0352b19ae4d9c9de1e5a964df089b025e0b9a057badf739838d8f023296b8df06b7e6eb11a29f04d1e1b5628fbb51aa9e166e60f1c67281fdca1055a71496b6d7ce10852ce4361eb61c3c7884d12420d800228cca779b742d15d3fa7c21a579c08dd75f5c48b0b97ef89cc28968a2bec5adabc3c953749b59010001 \\x0d47d89ba8966cd4f370d4f5b7dbd008940ac3b1833374eb8bc1f7f6bf3cf71022826d2ab751f8e354d90653fb457dafb37b176b3b1cdd427a5808b379e99306 1646215407000000 1646820207000000 1709892207000000 1804500207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-193 \\xb6254cc2ef251314d79e3bce3bd65c301f1ecf94924463b1c9f96111b4837fa865851ef3cd3ef083d702d70361298b44cb42a47c109622577a1b231302671b56 1 0 \\x000000010000000000800003cbd8fbd36c8bbb948d49de237e969a10a26d905ebb22a3c7dac5a9538e64bc29b37d1c75477bbb4ea542bdaa9002cd45e66e17b012b40e9ff1ea9ee110afdb028156ebef11c758d0d058800a3772907f035e11caccd3d8b7efc157539df08b374876ff2dda19a694b47001bde5c3faacbdfce750f2f030f336eb2ae16e9d310d010001 \\x3d93d5c1074fbc14da93fc9b10250b9fb2285721a9e07c6a92bc24fee2e1a2f05c199db56f34f1860d8f89488ba1577b144424f95b3a478b39b924aa11cec602 1638961407000000 1639566207000000 1702638207000000 1797246207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-194 \\xbe310f287faaf9a81f93db3f942a3fcd420bd70d2023fbd329eb77d761ada67ce377b1667cc560865649b0f39b9158f2e4ffab357a9f2f7132dfb929c1111169 1 0 \\x000000010000000000800003f74ab7f2be6f064d68bfef2353d08277513b1366999ad831c22937f13bf64b137aa064a2f49e6e9049db321fa85650e2f80f984f5a8dc2c5a2cecea884ddbf45b2ab01abff4e98463ebc3a269e0bf223dfa1686b32aa7cff429059a281d947b9f44ffc00c891a64acbbd7ea8c0502011238437239989aa3ca410391565af860f010001 \\x13ee44560d3c37eab9c9f9d76a676e639225bc5169146a76d49df6e02764aa022988656ad1dceece9a82e7a3232450e869007f6408f40b142911078281fc9d03 1642588407000000 1643193207000000 1706265207000000 1800873207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-195 \\xc12d932fdd294f70682fab6bc941018548cd3b9a029fba0c022e3690f971cd5ac7495524e54881be329bede1d74f74278bb5924800b46137323d318fcbc84259 1 0 \\x000000010000000000800003b663038a3bf27e5fc53d28b256547b10c814b28c5b4041be45f725b0ac33267c9afbad1da56be39a4601927b58b081b40486d91937a46421bd597c80cf0d4e6efc024e1f97e2afe176f8c780105d18fc55d594fcf9c349f0340fa24290a8638bfb2f8bc272aafa2aac234c382e9f46611b1fff02a18f295298360bb05ac669d7010001 \\x959fede8585950c509a22f8d0ed2dd2f9122267452003879c395d9510b647508d563224986ff6affa96f779e7e77a20d2e44064bb1819eff32141ca8e30fe605 1642588407000000 1643193207000000 1706265207000000 1800873207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-196 \\xc31916090e230e355a693105b6289ef60b7bb0cc3f455c912e8bf94f035db38bdc9209acacbe0226c79b910a11a367e7065efb232907c1adaebd33b97b04b48e 1 0 \\x000000010000000000800003cbb04543ea74b38d7d45289160109cd3ac5af21ceff406c0234c42b3e936d62fc79f13e7fb33b22cbc289acbfb479085ff1063290fb001c51a3414603bd78e20b925275aa33c26c591d5369d3f41010b79eaf74bb3eea2d0decb6032ef774e00f88634c1b9e6912cd63575f871040a3218809f6c4182532af352bb57fc33a08d010001 \\x32f7b27d2f3bacbd2d07dc66001866c1e334f18ee58648d66abbfe55d665622a7b803a8d0c5993c5dca9fa642648e6191fa0d91b0c06ffb3abb5b41ba3449d03 1643192907000000 1643797707000000 1706869707000000 1801477707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-197 \\xc56db23178c248b92aaf72a057228861ec2c91510fa83b1be1e1afebe3d4625f1e7080e9c49e2c5af6ed22f40e8aa43539f7caefecc4bc4de4f406434e043763 1 0 \\x0000000100000000008000039e3483c36811f629ba2196d23fe7be0d4fdcf3f5609c80b08c18840cae3269c0e98f51ec913eac4d7d11d07fff4c87a875476d33725495330a1385f502fed976b276d6ad016acc14f3dbe8f51da4aad13a117de29e0388999347da6d3f32c755df7c2e75ced27e7a93084d5757f8c71d86767d2e862309bfb586c748eaebc55d010001 \\x35028c8485d6878f6557f9fdeadbc4ee72542ccc4b9e2ebe6c6bd08b2db0f8026f8f8075fde46e3dfcd0d3e8f68d524353424f0e207fac118a4205cc6bcdae04 1669790907000000 1670395707000000 1733467707000000 1828075707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-198 \\xc911eb63ddf4593e2bf22ec8fcdb7c14b110a94bbda5b665120154a658a277af41823dec12932027679ff673d4c044810a99b4c4750041b58505106f7a5c791a 1 0 \\x000000010000000000800003bdc7488e0bc43ba83017618ec98c1cb30c861c4aefe825973ec6262751617bbfbdd953d667b024415cd16265a0adbed7499226e5acc703880d4af291580262ad2bb70b941d330b904889de31100fe283fc2ae65fee94a1aa6217e48d038545cfd59c88e4e6014b0b1bb3e059a1e27d62efc1d474304c01effa1a707f5d178ed7010001 \\x2cea549813d2778703d0e018068a3c3029803b3406d9677386f7f111607920efd16db21337a210e9cfd74fe3c5480ecca28cad8339078e61fc8fbc11b8186d0c 1638961407000000 1639566207000000 1702638207000000 1797246207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-199 \\xcab189344176559c67fe9b69832cefde8c50c24f06505e0bb555d9e03c69cee9a7f512934444cbe117e2769118922d7867c8e1944f5b57dad45f00b0b7592ce5 1 0 \\x000000010000000000800003e4fdb48b143c74665c7f682be74116e360fbf9e7b54b9b248deaeede0c2f60ad1e9daac2b1557d3e2d67fac63149eb01d5f21d81b5f7475f7a32968c404781e5dc2665f72adfbedebc2471677c5b2352e851f18f617d341267d8f14000ad65de47fc34356dfc0b4bcb98df87da25da972f056281a493d41a6c18ce904bc64bf1010001 \\xc2c8c367b01c3d19d460562efb08f192433e6046559ec6b221a1c23d8e7ee5adcefbc27277042cb9a85629fc47ebf8601d3b16f9634420aa7364e827d7b10b0d 1661932407000000 1662537207000000 1725609207000000 1820217207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-200 \\xcae1f7f7a294307c77c78e13b28a1d1099edd87274c2402f8afc9494d19f02c5fb6902dd0ccc2be61e64bfee81cffd99f984eda0a288623d111f7436d4f2c2e7 1 0 \\x000000010000000000800003a19b66d3675adc0029fc68de5d2ed14e0f536f82f9444faef10af20c164157a2b371b32839c91328abd7e94a2b61de0d0daa7d6ec034ce103ed7bb246788f81f3bc45f6bb987d99cfa77d394b932e650a2f635f87e7cd5c98bdc9e3af554ff10db0830e27643d287fdff7ab01ba1cb33abc6e4b69e70a89e1a652d021286ccfb010001 \\x2699b998e0c51c2e6a5612b0c93e47d9aac9eab8e6339e31a00bee67ac2f3fecaf3b9118cd4ca152c06074a0fc6e5e063f20400bd734564139a147708e29870f 1651051407000000 1651656207000000 1714728207000000 1809336207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-201 \\xd109847edf2c15c28716ffcc43683e14ca70e6af7d807506e528d8dbff992db7193f6199578acfefe7b0d4ce676ec92e73616280705d0fab16a364c91b3e8e78 1 0 \\x000000010000000000800003a5240d18b96d39802421cabb9340091b848b9df1eba37b7d34d32baf89a5595738193665d07e7ba7f4cfe9ee4b9635b8b4b62305ed8e763bc24bab6d15116d21aa3c183105bae5ca1e65f11a8667e1b4ddbed603e988eb5ce0eaf51ef69857818bd8df6134c7cb6e4fadc65e162b151f679bded110d8e915ac161a8b8b7c7e91010001 \\x659918487bdb43be6000b7641716030f6006a13f7ebff6e91d2d26975602c5f1ee42501f2fa7e8e3040799430a0dc441daf129eae7ea47bc33afc09ed6bd160b 1659514407000000 1660119207000000 1723191207000000 1817799207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-202 \\xd169281b8ffb6b8992677044f70a8ef5cef056ca1a050d91bc3e298e106623cd2a75acc49f252b0436de1a25f21e1005c9e2894df5a6209c9bb6dcfc20800931 1 0 \\x000000010000000000800003c4ee7feb23063cbd5e66d04f41bad02709f28528e0d9ad6606ee8229269add7184db4fbb000fdaa2b1e90424bdd75948e5048a7c0dc6e180381b2f371d137a9a59ffc497956c49cb4fabdb9bb2b12990570cc1ef6bab6d33bf61882aa52d7abf7be72bfd6f1aac8e00d43702f2f6b35b5e5b9b5a4926e85489201e1c4fe51e41010001 \\xb7f8ad3396cfcafd3015c92fd85f26f229c6ef75a38ee5087eecae29207cda8be81622e8d9e8bf4f200a9c1fd6e2856237abdfa17460f6452a3146eaac80d104 1652864907000000 1653469707000000 1716541707000000 1811149707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-203 \\xd5ad4dab8f19fc53d72e7c9c74a5486ecff31cef8db021c27221e94fd8f2c9973f6c3fc9c4af94918a8ea70470377eff295bc08bb66acfaba5de12674386250f 1 0 \\x000000010000000000800003c89645a167333b134819e4ffdc80d30defe143a9b0178d165a36edd0ea03d6eb4a8dc1761b1acee1908c3d90c232c1d7921f0f912e1bf00133662911d2dde6de8daa9a36872bf05cb46aa5313c4d71426ec102d09d80a9dc1e81905217dd39c4a0d478a543e3ae29f27da9b50a7f90c24cefc26dd043daa12b95264ea89813e7010001 \\x0d6297c12b6d68c515cf180966d900fb45bd06a160e84e6acfb731c8b3b623ce02789c73be32004900184637b19333a3cf1d99730acf0c1d77a740a346fad603 1649237907000000 1649842707000000 1712914707000000 1807522707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-204 \\xd9112270dd7b467cf5ca8da31a72887c94573720edd6a4b40bcd3f43e3357c869bff87e0a4fb0b8da02100ca5f246bfb3eb2b33ce4ca3bfd610dd7f6ceddfecf 1 0 \\x0000000100000000008000039dda3c5983f7302093a61b51a1f528f4aead6c7b9d9d748bf0ea729a10d49292640e29c0bf80f7bd7b9d2aeeda6948040a5faa6ee60bc87de2fda9b74c06fb0ad4e581a9b28e7ee2b8be811182b4e6c8905332f40accd2da7586b86546638f6cef174b154eae46577b7fb19fa4e3213257673904d0318a4be814dc2dae8e0581010001 \\xe6e13b60364a87f16a597f7c192ef2aa984a4772dad28435a996f0f91f8b5d80cb3cb89cd1940d554ba9f7c34595f7499d89218dd57eda34765cba1af6a62b07 1657700907000000 1658305707000000 1721377707000000 1815985707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-205 \\xdb31ee2110df3886c129d528195e115c05012cc8c29d684f8fa2f824e260a4accdfc308932b6b72a780331b2edc871f9cd521f334cebcb41892db7b30ca38c1a 1 0 \\x000000010000000000800003b3b768256321e3d9de9fd4dcfcbf591e857aab71f02e6a0cacedfc859c0b1e288c9458b868aa5b3c0ce2e5f1b67c7471df57602a00b41b4d312b187a5ac4a0c2d2b2e35b9dc3a2c420858daa5c649b0bec219fddd3742aa65e5eed9f2da4b1f68116ab22a929acd1b63af3e1135ac02f78773555ca9ec4c0aa6291583e41a005010001 \\x509e08d9ae41241e9e7c8ec354f521dc28c4d9cd05f2ee95db0951809a7a476969782acf2395eaffec9d5525c48bb2ad181747a19cc967ba35cc26fc1a3b2206 1652260407000000 1652865207000000 1715937207000000 1810545207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-206 \\xddc11b18c5d1eaab5b62df0d494bf3b28fc82f81828c8f3ea7fcedecf71958e9b69a7fdf80cf12cb3bd862d0e381914969cdfb95221c4bf1301888eb54607521 1 0 \\x000000010000000000800003c8d3e097e0b87243acfba162a38a90887555feeddc355bfdd641a2a4bb51d1b8c1581794fbd63bc28b92c3f0ef678089cc44f7fa5d843f6ed4ed91fc297e9dcda5c47103f1bbbda0ab23516feeb5e6d22caa240a149f2b305b3b29b523f7805001efb0e2184e43a5990dd6263db6e81cf70ae4b9ff46ad2ed88e36caa6cd3029010001 \\x515ae5e6c6245a8d33c58380539ae73e68d289aff7644a086131a0bad64ce959a1740e2d15410673776910bc8558c75c41e1fd0ddfef99f5e90068d4b9e6ce0b 1655282907000000 1655887707000000 1718959707000000 1813567707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-207 \\xe1a1dd9014c648585430977632b5e346dd69df35bc96c11622839f4b42f7e493dd5eb3bcc5fc2cf95c53e85b3710a7c0df239eb92e2e23a7cd26f65564a045f1 1 0 \\x000000010000000000800003d8f013b31b3a2465cc3ff29cded45608df4aa24ab94c05ebf4ee1cb38d6e8bbb810eca8b37fb449228fcc2b6447afb2cf456be1a87edc3e96eac0438b6d9baffc40dba97b819d705d13f12fb847e0ae5ef94a3506806d80c65cd7cc1fa453d88c085e90dc60fa34a37732044615c31117d36d20216c918e437b2b6f1adb8d7db010001 \\x8183cb294bdf1b201c87c11d5ad9b7f0088276a8a56e07fc8961035e5acfd15c934f4c26374633bbe399a568078fad51e7c0d837479aad23ac38ea009bdf4a0c 1667977407000000 1668582207000000 1731654207000000 1826262207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-208 \\xe255f4982d9b4785dbc70e1e4f2b060f334b2c90c36380525ac2700b50f0e1e329d44122ea75d335808cec8ff81877786aeb75195ac672205de5184ae6104338 1 0 \\x0000000100000000008000039f9d77732f5606fcfc048eb5dceba09faddbe1a67790b7c3b44be159bdbd92220249900bfa9bb43be1672276085a4f36f9e4ccef5c9508fc469a4a2327b343039d81d3236830488cb399d3ddd55f2a8d63c613e3fbab52425381e547b52e393a04deb431f812200b59b1251d3c63de2f16b0f3204d7cdd03c54c248ff1dbcaab010001 \\x44d566d08ae79f2372e0066010ba2024315617883ff75b7e283fcef0cde2ac92d40f7aadc1cee7a109dc8d5565a4e9f6230024083569c382305338be42b48303 1663745907000000 1664350707000000 1727422707000000 1822030707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-209 \\xe3cd6788b9be307dea9267b4e306c461f9a429126a32ab2bce1e3d9f95ef4e3e548bd6f64b2738e1094bbf19003718de33ec89d9fb404ecc2b0685b11f77a691 1 0 \\x000000010000000000800003a9c042b5f132333425b478312fe94c1514be56cc46f5015d10a1106bd7d49764ccadb2456f9d747c74c7ecd1dfe428c3c6fda6e366f73cec06af290db0a9f05b0b96138dcfc06b57e156e76f79abb472fdf088e09158c716372339e4d95de691e06eccf89facc7b7787d5cb46b8cd25d4c7c0f3a0301b18c06fc55337492e67d010001 \\x4ca4e008af40ddc8af642dae461a7feb1b27f7228d76349fc5c961b4224c59745c399a996d4d5816afb8a757192014c6678ee588874cdf26106b6076d8beb60c 1661327907000000 1661932707000000 1725004707000000 1819612707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-210 \\xe499159b9663afe4a8772e284c16f79fc2e4a7bdbfad78a1c2b0d8440b5c0147cf77ae266124f70deebffbba3541220c3120b1f352674f25acfc332a19ddc568 1 0 \\x000000010000000000800003aca77ed3a57001f1b5acb5995fadb6ebd98545ae4cce25ea6b1f9c355e2252885113d945b8e2dbc55fd4dd46261edbad1ff2449c2f5aab5c73c0b09bd2a7939860433c754e34a9a281ff5f0145baf73a7c2156a91b71e32c6c9e570864904d4aad1432e9e1bf3235826d0d530f7a5b317ec70cd9ded09847102c7c0e838e6261010001 \\xdfd31c90da1e5f8ce16992e3ba14d4d7c45ebf1f92536ad2219728df39fbb8338cab8a52b7a9cb5424f6d87b611cead70a3463aa4ad617949cff03a25e91870f 1640170407000000 1640775207000000 1703847207000000 1798455207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-211 \\xe60d96444f6b955443e17dc9894affc74eec98c934c3b68db954ee11324ae62c9dab772b80d2b6ffd9aaa9f7229c96806b4284f6c1ee6f9ad6e18e5fece5c2c3 1 0 \\x000000010000000000800003d9848fba9984d9ff2070053d778ef7af94629bab191fcc93f15991745361214bf6ea15e0458de68e12dca25e07f6e316c2f70e8ea2f0a759ac908d6796c77799e8a00d4f662f61b54b5a53f1d5514fa3aed968c07e7ab0379868d8c4c2cbbffbaceaee6bf65a15ab2a4b2cc9f348a5a125a23c4b6591bc91c7061c262582a49b010001 \\x770a44a4d0b72d76937e071473b8631d895f70dc1f6b706e3d37b06ef4a09ebdb3d67bbb906bac047d3c58faae4d81ea27a4fd52701b95c02cc6b73c14807a0c 1645006407000000 1645611207000000 1708683207000000 1803291207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-212 \\xe6a1ff563df017dae2134e68521bd21fbb05c44c02005be4865fa8cee31c7f1ae0f368408e0ac773891abaa42fdcdd8b322a598010ca0ab9bac81a3986fea2cc 1 0 \\x000000010000000000800003bddd5da982c364d1ce8f9f4f21a7e4a442d48cbbf69d827a9365a3d406683f950e33d25fdfba2d1e914aebb6dd6f5d58bee1219b6c9f081f2be208c9f3ca0474e68a67334c4385601c491d886ee49bad25e8f5b467ba48c2ece302b385c5c0d6dad697ea4e7eb6fe1c954d1294c3ed1e07083b31b70f8f65592c9604b12d8713010001 \\x5e8cf583bdf481b03c4431bc5c9e92214fe1b71e00253239959f21b71e955bf161112568fb3e7b47e6648225d3034fc0fea7dcf58df35419e00c71a9e0ad9504 1641983907000000 1642588707000000 1705660707000000 1800268707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-213 \\xe6e1b1e4eb7618428c93882f567ee7637b05673755943a2a354d2557b505ff33ad2fe5e5d98e5dd7ae6a5e010582b3b7c7abe4ecf2af71d7afbb89eddf27203a 1 0 \\x000000010000000000800003f9277c06dcafe96c96bc30c0dc654be168df7f85ca4d241ed2f0e1035a542d821aa82d1bca651e2a0f05900cf7d3827f7c39293c936604b41171c83ed42d587194d3d3a4e3eb63d245e72142b230ed4d28f98866b6136a3afabd1c59ab70686afc3bb16b5e01ad515afb3a6438a062723547ae403f48e011574c87b205f2c2a1010001 \\x70846cec056321de8a3de71d37d4c879319022d4822695214e3d39fe5bce787802cc135bf751e42f35aab5ea40e26f47739b566893c193c3d5d084f19a5db801 1668581907000000 1669186707000000 1732258707000000 1826866707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-214 \\xf50985ce7378d191f347f05fe1422f98217b8e0684a0bd91999c9ec10ff482955f38f2f177c618a239d500c35dbc0bdf37646b9844c80954d87bea1398f6054c 1 0 \\x000000010000000000800003b834cd76e4d0474354e33cdea07d5609b36265a712cb4b63a83b3218b236dd2e0606355e3df305c354331326c7afca5f6c42714437ba766d2df1400b59b7e7a1206202054226f21b4d3f2def732bb93d373f87432a30f509e3c45ee9a74438692fb2659ead577e77c53749eeda583af33f4a3f5666495c2aefe313a616d61c7f010001 \\xdbe51c3bd7db39bd721c881ed561edab5f9c35e5ef8909ba03516840d487ea7b8c0e6a11f75bbfcf4b1eb7a7c9ef823e7eaeedb710bbe5335719ab40c9aa5206 1655887407000000 1656492207000000 1719564207000000 1814172207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-215 \\xf7d997f3642fc4468a9665580bb46940f2547f616c2f1f77e2549cf59b4a449fcef1c25c916dfa1b87a64950db674ecb1369336858c9aa0e3fd9bdf08829d157 1 0 \\x000000010000000000800003de010eb45f6f07b101e2448a5318227ba186090f28a81764d3ce3f89e77dfe35967b8d0c38d9136c117deecdf9e332839db5c9268e5eafc487a1bfecc8ba08ac285a1ed617436a47ff29f31a16bede8f657ca47134117c126bc1be6aa52a6c5fd50df1d952714bd40d7ea77be65cdb292a1c3a111cebd80535de6dd046b85f2f010001 \\xb062dcd1afe4d98ef98a639484f64b195be1a202775a98925f27299901fcd16a648cdbf9e4ece63c49ce496720f8a816308d02352543df733407a45d183d4d02 1647424407000000 1648029207000000 1711101207000000 1805709207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-216 \\xf729ec6bb2cc6814ce53d630750ff2ae97cc4ea5311d18cacc2a6b4125307cbf324c8a65da1947849a1f957f628a1b7f7146cf0813221164d331f33d0a3743c2 1 0 \\x000000010000000000800003c42c52ee18b4f7d4a85414881cd2fb415f717a7c6a3f1ca4d43230a4736a7c938056071ebd0580eea4845d950746216258db269f65b411e1be733bef029091b32d3e8d0ce6c10c90ff3c574d4764c86c25ff5c180740510e2b6d70f5e11337cba4af08210cf3ff5736acbecbeeb8fe91fbcc1476dc67e81aba5ad750d1da8dcb010001 \\xa91c59fc5c8a55f8a631c68db2ed7f825ec38bd2120cd0eec4d42a00185fa1128fa699c518e89afc85d6c3781abb16c8205a2875c28f74bf499a14ff14466200 1661932407000000 1662537207000000 1725609207000000 1820217207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-217 \\xfa919294afb1b77bba9ccd73ae5ffecae90a5081b7185c5a46b2f91cf6b16c5a7491967324d2b114a330a7874a8b177db8a5b024b741eb88509bc9a18cd0ec6b 1 0 \\x000000010000000000800003d56c08d05e42e816cb6be8c2ff52a2886bc6f0a7880868661fa26f66fd8f4066c1c366a442e3c16109462c2cc79483cfc2fd1e5c8f110c432b78630823666c62759f75f5d36253b1b757ef7d9b06c8bcac18fc30c9b85bf648decbdf25a74d292cd6ed94ab0493ef8f5178455646e0793bd58bdb469c0f6e10cf4d21968b6671010001 \\xff6000f8687eeb87ea901e764a0db976d929ebe3668c364f360563eeacf95fe9e2a437ba60e8549cd4c461df1e6ed4c8837e785dc1046a193aca6c919e929508 1660118907000000 1660723707000000 1723795707000000 1818403707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-218 \\x00125a1454a77aa34a81240e0a9449cbb1488ac32256d969653156286329dd3f4172af83de57595c68a39aafbf6d2dde3db82ba0b128151d3fcc6c822486c532 1 0 \\x000000010000000000800003b9dfa3aefe5127324b8edfd739dba7bda9353d244dc026ce31bc681ba0f3c56e98978bd663e66b6551d053bf3a23546255319a3b3b04893342a9cb5ea79a7c20ad9271600ea142c9764fbb736b85bfd99675faef9b350f1f79c9ddfee5ce85b9bff725a60042de5ebf5e821f9264255387fd59284741855baadcfee16dd22599010001 \\x91c7bd03a85a33063d41963d61fbd203d5754692755aba57c6f1e8adaa0ca6c580218791cf40194721b64404a15ce173b4d54c2b3d6bf1c2631f91bb0928030a 1653469407000000 1654074207000000 1717146207000000 1811754207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-219 \\x02a6012d562301b8e61092590caa7cd999d3c6b81fac47dc77d4673d341717cf2921e341beb8ced80b62e14e5e2163f4cd421df22348e4b2ea4768433e3b8541 1 0 \\x000000010000000000800003adef82c1f953a5369d0c5563bde18faa756cc94c506db8ccbf699f4c0514d65843dd0326cb891d967b676c9a56770f099e87ea05eb880fe9e53be65ba30f6b30eee5cd470f11d7c43957c57c97ddeda096bd56a4169ccd460fd4e9ce7d346a0772aa17cc1bf2326b755e7ac0a4b651bc3a97f30bd5b1e459359084cb4269d4b1010001 \\x14caecad0b421802af513280bc5c53fbb5f8ae7f046ac89e682ecda738e7bae5ee45b4b2b4bc246f7a0c9ac2d648d843adab6ac0b91fd5f54b0d99bcd52dfa02 1653469407000000 1654074207000000 1717146207000000 1811754207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-220 \\x02fa3c3e9de56e8e79448fadeca0d1725588152fcbf7cbaa3cd79bd947755a0b0ba7bff74a32796fdf98a5bcb7fa996aeab0734010fb7841c7b0e7b99601f37c 1 0 \\x000000010000000000800003c1b83dd2ec46b39ca8504c5aa48d12cd42bbc2c5277110e8748b340ab73ceab08cb247286f090149569ab7e74fa28a78876f0ecc7c54eddb3a75d99d853e0302c96391fa41fa6c5d46d19b115a9966fed822fa8b5b55d585b371c986528a59daf1171100dcecd44bbc124c647097bc9f8fef481041473787d66ba0f001eb599d010001 \\x0f544eb0762cb4d384194d3ff76d5420218ff162f6ef31b8bc370a59fbc7e448b490bfd4aaec09782292b51b5553f6c38035c4b7440167f58766507f344a150e 1645610907000000 1646215707000000 1709287707000000 1803895707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-221 \\x02ee0b3c0929792003d1ff2424b732a48ba9f640e4f2b39fb23a693d6005cd2cecd9bf17a3422d6c0e9ab71fa88813d91598486fde2dcea64809e2b434b63658 1 0 \\x000000010000000000800003d0a697a69d074a155ba320295eef305a31c9ccd20d933d6b3bf9827500ba0fc4c3b0e49c56d6ecb9371a3f201b0929c87f97857d02c427935621204bc4c58c7ac39695f2f4af89e2c35a11444655fae82a57f02f826584bd54e0d579bdc58e8b40a9f4390e3052a0f845ed274c706eaaf87bae3c71e64d514d9120edf63de0ad010001 \\xfca0e752de39232fa51033943a48c988cfaf1518839600500d90627f9e53c1ccd99a16d7f7d9899b809ecae467883d9f6f686a5360dee626c34960cf1a01ad0d 1638961407000000 1639566207000000 1702638207000000 1797246207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-222 \\x045aba5d8a13da62aa104c60f9303c30cc15dc8845e489e9a951585ac74e2031231a86d0038063a47f5fdeed7d2236f709dd39077e09a84581ab99e8ebc83d0b 1 0 \\x000000010000000000800003d217265cc9c0dbdc83eac8f1d67c06a289b22df92b8248396adc75f244581ce5a803ed9fba9c0149fdd259dbcccc9b8d8799ad16457c3e69ff7858f3cc7256b2ded2d9e4acc31c5c07178d8c75cdd4663d19bdc89b81dd5bb25df236b61bcec95fb7af3fe8a9da8ab21b613ece1e02c67a76f5c88c7a04c199a9330039fd37a1010001 \\xf103d45b19f9c1a3811e0ff776c2f773750676aa2bd5f29bda7a075e9b3d9886007c3e9ff4ec8ea80da2832de660aa86a8c500ce2e71aa0a89921e811ea47801 1667372907000000 1667977707000000 1731049707000000 1825657707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-223 \\x07e22bdba146c10f658794f8c024f8633c4e55b6991376be39b36821688eb944da2dfd50a466a79d44f6de15ebf2bb229dfba84c52ea7abd7f2af0330dd0a0bb 1 0 \\x000000010000000000800003d17bba50fbdaadfc7291645cf7ab3ba6e1e6d942c94d1e04888ea59654c8e551df75e40cc037ccf7147237dd95ee0b7b293f338dd7d0d1e6b53c0a3299b5bb442bf2b0b5708b6de763ce9724d3a0320b637db222ecd937ca9a585a40a225d873f6d0170cc666eab435dcb37fc1edb1fc799628abe32149edb8af94c7e9a47c7b010001 \\xb5db937f476e6095d41615677d240255baa08cf99609cc2e2bcc24fed69e00e125fe8c50089e5f832432c2f37c392fc1a3bfacf3c639741ccd920441b0d2050d 1645006407000000 1645611207000000 1708683207000000 1803291207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-224 \\x08fee60f3ef005eeaa63ca6f5905a87ba06286369200192a35bf7fce0ada972595bf4abbc78af36d4d1c56d74adc256f5fe9aaa4941ffde7ff18c687656f7e3d 1 0 \\x000000010000000000800003bd7c04f71b705c7e45052ac47a11c357bc44c14b4d579cf4045f9f6b697f1c17ece56e092875d3a7ffce468607ca147913063df988e8ac4df63448a065c02c5571a2ad353a8aa722fa81b4a1c927a76e3702dc3a52be4d0fb678f5eff7e1b51e3012a6a0dba54bc861dfe15ebae535c07636b6cd2bba5fabcaa61948bd250387010001 \\x33634f0041961cd5ddeb0d4a4d3a1686b4536b0659aa91edf690003addd53e6059a2c8099514420383283d49fc97cf76e34cd09749d2271c6d86fd32bfa9010b 1638356907000000 1638961707000000 1702033707000000 1796641707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-225 \\x0d7262c06fccbd30d6438e53f75b0a053ba4100e2503593c76d3173bb6d493d4d95eb50e8e9324345f4360c02ccff00b18011824c8af7cee94cac196ee98c6b6 1 0 \\x000000010000000000800003c2e8756b3df008c3c7850821bc42bbbab7633aecb55c7ac43f0d9a4249211b0bf9cb35f6020cc219890200a1e141a81e91b0e61c56363b94bb7b0648b6c6d114102df631db3a0ea50600d16df012776b6d1af70166ce2df9456cd9f0262fb349f71c88d78ab0918b426e79217363336c94271bb7239ac537254526204ac81387010001 \\xee246452d53acbe4eca8a68ae7ebae8efc0624f0cb2cf2df16a0f6a53077100d4a602e4874aafcde13defd2f0ca98b1a4c6d506f21059615e76f233951ed140c 1650446907000000 1651051707000000 1714123707000000 1808731707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-226 \\x1386f2b5ffa41410cc46b0e725cab3e4b8c884bae6fd732794b9ee41809a0843df35a5cda11792bb819286bd23b81a092fe6c113b5a1ec27e975d08e865d846a 1 0 \\x000000010000000000800003dbe6c736e999be5d0af1dc3484fff5493dfd6201ecd042176bf1ad4ba38dfc2115eff74958dbb6ad4ca07910cd1dad733121ed21d757c1746a315e2b9a890dd4067c6e4d420f388f7591493fbb1e494594ad50957ce46dd4902c44a446ba37810a76731b94692d117a80ae9bacfe2d8e15f933f82342d28a9e0c2f9060e37d0f010001 \\xc1880d387cabb19d1d4a793a4906a8db6b981d2b07381c1b377e6f7335006698fac24bc1b86de30ed76c8631394028dd7d273e43d6dfe70c3d0a5e697f493b09 1662536907000000 1663141707000000 1726213707000000 1820821707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-227 \\x18465ccbf0ac49c668ab384f4f4dee141d317d38c9bf8019bd01b85afc88d20355785fb30897f41214664368bcfb6555f75cb3ced2a5b13a21756ec0308575fc 1 0 \\x000000010000000000800003d770c2487079ba2ae8eb9e99bc8ce71c3b975b570fe09fd327b67c4f9eba6ba812ac81e3a95eed14e9e3226d55cff4cb38ca3c184bf42f46c3a0b00bfd6429450d73d0ce585cf6f9de17618ac35048e872005ed8a186ad1a197b0526a78e297beda4563156f2b1b67577d37d90a689dfc64d33b81665bd1649e7df60082e4ec7010001 \\x1e6d611ed44bbeb53540e6f219b670ff6b323e9877a8f617c5dbfd91d59261d20c843ce012a97e990548bc91612aba0dfad0e60375d518a9b0c02c0313844104 1651051407000000 1651656207000000 1714728207000000 1809336207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-228 \\x19ea59f9aeb1f765e7a61582f3759bd4f18ec1c2003257a8351e36bf8b6655f2b057e87858d8a96cece03a7d3c4ccedf5ca7559bffce7090c151269e668a717b 1 0 \\x000000010000000000800003b8230dea99f666f382d71d274276038de81ebfb5e35fe6cb1ec65840fd762b6298f7408dec21c0c14dc3d4f118496feee3f183a72e2342eca4d1ac51e35f24381aab332d14621038f6f3309d12577b21107b6137c7f371dd45e43f4b50c8a78ffd4c9479d329ca81d5f5f5f2df439a7ff87b4b31b173d6980f7864dd7592ff3b010001 \\x8ef8cb8e306fec81c25512c80ab24c20a563fe130f2fbc8b1c64291691b66de6b960e9b0a368d5d538076d40b190f98535bbc1b38a95e5e9590af986c8827b01 1649237907000000 1649842707000000 1712914707000000 1807522707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-229 \\x1a8ef1e8d8b254a98a03f43a0b829942a5eabc897cb6b08b02e8af70d47cdfc1205131e6bb3ef85a235d66be7bda56daf06cb5d7d355b7274e31ca9604a33c61 1 0 \\x000000010000000000800003d8a7d7af503c75517cb738f4e51942070f7b97b6e1eb575b6a0ea3c5a6adbe37dc1e0373a09bfc49ee15d36e3d8c4751eb3ea428f60656b4fcbeb28cd800cb66444ac45dae5014481c8db2dbb4f097ff96e20c4764dcdd8f461c6ba846c506ce4029a7e4f71fa891b4ccae4a2444d3a40131ec536548f1a5131377ec0760f1fd010001 \\x7168669f8143ad7fda8a8a61f583efa986af7f20137729ee0f5809890420d570c80a54cda30e9ac08ba39587a6f16a034c84d7ede70210cc6249ae44217b7102 1660723407000000 1661328207000000 1724400207000000 1819008207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-230 \\x1a6612b1b553fc142172379ee64db345b50cc413d37f5db2d80a5b573c9c687a1644d806c9512c5cde734b7286edf65dc9b52d291842e8831ebbcd35964adf6b 1 0 \\x000000010000000000800003d9ea53e79fccb2e652ad511e778a30307868bcc42f9467581fd828c8821c95dfcf6d4834b0ff1ba181e9324c73122587c7e7d89c5cca6028ab30275b789ee2dc69ccc0ae4c3e40e38b65fe9eaba865ffdc17a1b2fab1646b9e33a67517cbddcacbefc1a202909fa5792042d90e8c0ee5dd5c6be422d31c2168ceb474ece48eff010001 \\x3b3b10918c1af8adbd2ea015a03f6728118dd5b140edc73e25c84e361832ce80cc2c16f76b128265feb5a2f5fb282152b9d28a4160cdc7244f470b16beab8708 1645610907000000 1646215707000000 1709287707000000 1803895707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-231 \\x1d6ed76d27239a844deb4cce5302c8bcf9dd9161ba88d73d5ba2a5cc848ea367c51b38679b64fe7139ce39ccc9efb2eb1e776fb222afaf20baae731a309094b0 1 0 \\x000000010000000000800003d7c32f8984b0d5966b6bdc95863b02ac40dcb4f43925c0aed1063a7b9715d530d5b5d55838d5102bdcf4551b1b92fe01ffaa118866f7a6fbf0b38f5309ac887b830da3acaf11ab3a0b0dbe9e508acd6883b55646a9eb9d77be6364bf3e25ee33e6496d12cefb4847ff3ec4f684a84084cc8fb6af5d493ae7d95e393c315cf583010001 \\x6421fee55a46288b89cb39cf4bf2ebebe59cc37361363aa3e37438af4b83dfea91b0648fd32173246efd69b06b1e17c0fcbfb0206f9b1ed6cb3ac65d838d820d 1669790907000000 1670395707000000 1733467707000000 1828075707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-232 \\x1d123f3ef8e61a069f4b85115a5ae378d386f767b575204e76d7b28482497d31c0860e128571af711cbb82b1d23669d0a8d9b6d7421f85efab33ad2ce33b2920 1 0 \\x000000010000000000800003c90c299fbb4b374e3c6221b88b2470a684ea2cfb9cd57fdb1d4a9be5635627daa22fee57e923f2e7a5a24052367eeab4854af326f70b42f9ff18384b06316ee9dd67506de6ae1171a26adb0b5f332042b08979538e27f82aeae401a0fbf7e3948169df89b8a2bc25bf0423e5e0c2588a466569740c632cefc063d7be90a64cb5010001 \\x82de49b819da356515146d22eef202ce71bbb3baef71ea9184445985459321de0d9017b71f3a29b2a868aa1686060414078fc6bade15e6e34c7a285672faab06 1658909907000000 1659514707000000 1722586707000000 1817194707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-233 \\x2266d9aaae00a3d8dd33b76f9f288c027f9c6b9ca51000f3e0b01e27a8d25708b6a201b29dcda02bd2f059ce72d741c2b7698be36cbd74e61252b119611b2763 1 0 \\x0000000100000000008000039fd006cbb0c907220480d4bf4a6313d0dbc5b7545d178efe66cc332e9cb1ca145f3a04abf6d1ea0486a9fca8e60e3400065db985c7ac0e159eb360f24c308faa6a9636b6a3daaa14f76e65b9045d567018dd88b1096b14cfe46eec86e747ce5f2330771071330f9f0166d4ca69e1ec38bfbba4d09774129a7930d7d9c2977c59010001 \\xfbb5839f59198052614df9eaa97f0eebe1390cd9442d7cfb3ea87b139e4962866df008b127b5108ae7e85850c6b753a855624b23c661af81056c3655048d2d08 1650446907000000 1651051707000000 1714123707000000 1808731707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-234 \\x229228f81b99ac313290fa5d924ed7a51f822afd024585b1c5aa0a17a719fade0d092d99f1825dd835943f840a2a71279916d1cfda1e4bece80edf8b7614120a 1 0 \\x000000010000000000800003ce16edf3faab14dc280e2b8d36b4f8e569d4097a0322479bd860a179df771c69858a90da07c22b46ffa5141f90358fc6af77621fb9856a6a48e7328135552570487fdfedccde48a85ab20e9a58c208a78481a3ce2d0fe5ae4331b03d0c591391746517f2c3675a0350accb50b7d542483a96451e1397058fd5df35c606e63671010001 \\xf12c67a1dd176059ef4a5e540a370ec124c835b0fcc303599dfde1c45df4520f88c5302c3adfe5a625a3ff9782e6eeefa96b1ac57a9c91132c3bf0e267711b05 1666163907000000 1666768707000000 1729840707000000 1824448707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-235 \\x23ae1b32e5412ac8d69350a683c3ca5e8b079f00f3256c6a3ba9d3dc97c8df78814d8d2fedb8a978c00560fcc8bb9bcf3101fa56032db6766ae1f163a18ad45c 1 0 \\x0000000100000000008000039900be5acb85ee1002cb1088c63d004cf91fef13da06a5800210b94b4304156e0f16121cf08914e3e4911168351868dcaea43c6b5d34244712e8764981a5f91715882b5b6462edbab15b473922f3e3fb6afc8e5a0b495a7554c6e3f9ae5b9fa40f35948aa7455263420e10ee5247ff87d3b3992ffaac8393c6d5fff2e38e5713010001 \\xa4522c71aa0eafdb53c13dbd176c42fb96e8d8e814675235367b7558bd73506fd221df7e8a0ce531a60a9dd201d55dc5e175454f91d903fae05a9a835e13bb06 1666768407000000 1667373207000000 1730445207000000 1825053207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-236 \\x2412ff56a20e86bf1099ff9efb9f9caa77f27c111d0ab250e33a460cb409f19c4cfb3a4fcbd9103d0a23c3f2f991535b2437177a46132c7d317b8d47b9e55fac 1 0 \\x000000010000000000800003d6af246230417a2a2f56e77b4c02aa1b2cc9b3a3c7787b5ddb27a172453a4e7745e18c1f8c89ac451b8b199e13e1110905cfce09b9bfc28ca43cf57a19c9fd1dc1c72220642b6bc6167a29fb205bf292fdf6fc200e640d6d423f85bab6c192cdb8282eadb1ba45e0ad51bce2f656dcad8220143c85571bbfa5b8940650f88fb1010001 \\x535e435646e7e13d8956096d8e4943c1de1d6b447f6a9c95c2a177c75f334295471b1a1577c58a4cc4826e8c50a6119a7eb575ed66e107b08d68340509d81b0b 1645006407000000 1645611207000000 1708683207000000 1803291207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-237 \\x2582ac7a4c2d856dde3c631327e096b620bbeb5cee5f9a3b7d430e82ece98e8b072ccd97b117ca027c5274790ee4218490c60216d8b91f8b7122d38ffcae35e5 1 0 \\x000000010000000000800003c9822bc0cb70db7eae7120c6924d834294e5c3bbbf7ddf5b8f3aa55745a2eb6c0914497f7f5b5f8a656598f382cea07663d24a0d5446c6f438a33445efad0c649290c27f615c5db6956ea3dfe437d984e0d40eb2b2913e38b4dff92312ec18c602a861aa85ed241dc3e4ef0277e1da7b32991670688f8012856c18dc36f32b0d010001 \\x6ea07d3f7ed949369f53a18265e42c0049652cfe9fd743dc3ae0a5a828ac9846db5eadbe8d0b7ceb028d833d8e65c4c37ce0d0f55ae7205c6c1c4acd9e58fc00 1652260407000000 1652865207000000 1715937207000000 1810545207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-238 \\x255aa7df8dec63d0a0117466aeb1412ca2d7c620f191b73ab6df8d3ddc47caf3cfbd3e051bd675bb696a8581e49b210be7a178787c579af6e50a6b70c43b1d41 1 0 \\x000000010000000000800003ab5b2b1cf300672cff7e7605d47f56bed0db0f2361198f3fbd870e421ca8f470d50c3c2b9aa8bdc9e9d5e8597d6bd49c7eacafc888040b3c33d00ae1a4762198634cc16acb1ea67de5cb0a08dac048f9bd6b6adfcf9798dd0b1b4d3245fe78bff629f04f0e1deb66b330ea43acc629608286ab6b4e595f5b9aa5fe11efe3fc95010001 \\x333c05b1e8d0ca2c2afaa7ab6f5e39adc2692ef3d84de1d57d744b2961090e87860f44830e73d6c3310d3afd3ce8c16661ba8143fea2d681ee126bb389dad70e 1645610907000000 1646215707000000 1709287707000000 1803895707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-239 \\x2656a93873b6e4b86fe608c42446c164322d310cfd41ef418a533857d0e12131325adb38f7c61310333a463681804bfa41a9b02b12e6b53bc5aa2e8cb3bce1d8 1 0 \\x000000010000000000800003b180082bfb7a70a3ef3f107e0b98e8bee491373802c777b02b2d5e3e94ba9f51f1776f0475a578e7990ea30f412c4e11c1997d8c407f7afe02b36479abb6d13cb6795fc41f900dbaf89e27e605c0c814bba64bc7f7a3d7f052e81424aa57b14666b3b9d9afc3f3dd477597aa7477168331602987bbc8d6bca0a4261bb7d4fea5010001 \\xdebd1db33b8349f376bfa93315f66de5bbb94cc26f271b3bcb0e62e7236b37ac4dc544a3d4b3e2008f709dc974371ef9d238d658f1097db9f4f6e2b100635408 1644401907000000 1645006707000000 1708078707000000 1802686707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-240 \\x2aae53aaded67407c0e02335240200a8b8fe7e4909c4a7f701da0b82297ae79e2e63d4472d927894a48257619ad0345f07df0e86fd392fcbb0f480bef4732e14 1 0 \\x000000010000000000800003d1146af35d4a81ad37d523af2cbdcc4d8aa2e385e75e95ea1a2d3f00ccd12088f72600747edbc19cebe731f5dc870cf8268ce1467db07cefa858e3aca79317bc07da3e7c160682b934cff79bd61a1db0a9c8b1660d0b2673e316bf2d5fbb8d25b543a3e1cc00b3dce6262a120a26e47387bc5fac34b94b2d2c12bc83c6045217010001 \\x8d506ef177c1e4b4cda748c4f40463bf7a105af73613bec170f5985521dfc6b7612e198bcb91f45b956d5255eef6fd6e2841078553431726ac6cc68e743e1309 1641983907000000 1642588707000000 1705660707000000 1800268707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-241 \\x30b65884f51848995ab1e3110047ca26bbd37a75fae5f1f87f0e1f495e06aa76e1fe58aa2dbc8c79c9fe617a423a994d9878d6c7833c086827446ba05e941d55 1 0 \\x000000010000000000800003a241864322528b508c8d4f6fe9f10e41aba1fd1f71a28f47ac1259fd2f0ca7be375990a3498d38f2705429cb4355d3e8f1a1f1ae8060801d826331357c9498ef21c771ea65b097831eb21d66bb37f2750aabfa2c15aa3b5619722b8783731a406ef2ad881edfc256d4b8e743a3bfa33282051f9c5da47ef9f8ed892b820e8b69010001 \\x89d9c7d334cac2819b61feb5aaf84f31a1c66a330a95649f92427a16b4326221b8a475c7a6871ab68666e25d4c5cfc4725125f6fc91bafa0eeab0391d91a1b01 1663745907000000 1664350707000000 1727422707000000 1822030707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-242 \\x329a4ad879f7d857b4adf5101cb6fcd65adbe1cf97ff01e37c5f9a72133b331e2abb538677bc2c12d06c2486b1a0ce1eff383ebdfd905e499b2ce2f85fb51082 1 0 \\x000000010000000000800003c63fadfc2c21fbcf9653a1325131ada17fb73c8ae5568dccdfc7bb70a9cd34fc25826ede47f7d07c605f82a536545517782b1e5d308ceac2e8dfe51088c8e266ff0369db5ea7d58646276c9952839977fc8d67f3ce6108a7ede146ee8c86640ccc85dcd36ea85a710881b8cda6d32c515f25ad9f2bfda7742cc5fb5606d8604d010001 \\x893ffb046d6cfbb23573644870f913441b19f855735e09ba25c99e17f7b5ed70f4afe6cb49b5fd5cae364f59349924eb9fa75a9d647b68fca95201ccf8779800 1668581907000000 1669186707000000 1732258707000000 1826866707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-243 \\x363a5be9ce32222dea1bbcbbd6a179c07e3b2abbfe7bb76c17e1c59d15f9b429d64a68ccceb3c8d1bd40f8730244cf514c2ff3c7bb98baa1200af1b5ba9d81af 1 0 \\x000000010000000000800003bd90f105d82bdf2ce6389261a5656f104b1e094e00e0a349ee0e85c20e0a73d197f3ed998ac8ba9cb05e244b402341c0b52776086eba53928a3b4ec5ab17fde240bb67bc999841aee2003ac8cf243b9f29ed66b70063c8c92f54bc9c3a523c15c79522f106c9f400d17e4b24b792bf3325ff74c2ef1ee4ff767d2dddb91143ad010001 \\xa5587de4f1223d476acabbdfb180025df06e4fc6ce8ff4ce926d48cb3464116eabccca7d5c550f06370b58a28613278e4d41061a87cda198b9f55b0d806fff01 1668581907000000 1669186707000000 1732258707000000 1826866707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-244 \\x36627cb3c2c3757cc98146d0ce481899826f4e3c51fa04f89aeab4348fd502fc1fd72fb528a88d6edfa7956565fae2e896f1e54ff952296d61561dfe1bb653ab 1 0 \\x000000010000000000800003cb13b59d36d5e592e9c6ca7105975fc4c722a82fcb6f56062b4a646ab5a43c602e48b0eaddcee86c1193b91abeab06e22268fcea0d447adf75d179402e88f6552bb5be03e25306d4a49ef73afb93a829e1767ba7e844c812ef726b174bdf441e745e8230bd17132952bc80432ca5594c6d1f06c6b963855ced3d9fefbdf82fa9010001 \\x3cc4a4b1f794ddd168e37f6b454c61e8a36cb366d89ce964bdb3b696c777b962c02fbc0c8ea775b48241d88a709fc4be9648270aa10e8f6ef23aefa3d2d11404 1667372907000000 1667977707000000 1731049707000000 1825657707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-245 \\x3c96ec46ea981ee4eef41e8db45be58ae342112ac6b872c5060a0cd4630c472e0fce197a37eac5c15b2defb531459aeacea85c669dce134d6d523a3be0556191 1 0 \\x000000010000000000800003df2b9ab4ab3ae39e8208d9a0f9ff51cdfc807d414579a854afaae3f457be1e93d113728b66f85122e40180cce12481146a5c3a33e8e7c7e6181f4477cc7f15eadf86086b1c52042d66c808275682951e0012af100666f0b8969d8856b5daecba8de4475732edcf52ea56ea4ddb3f0a3835bb8b9122dd4fbee2753a60b2e78079010001 \\x810f486924d5448d5853d8d0c165fb94c901dededd59e509552f500692b73dc9bf0c058b967f447e68b26ccb7db6be409b39562bfac66983d9d0f21c16261d02 1640170407000000 1640775207000000 1703847207000000 1798455207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-246 \\x3dca7d62252d788302b98d56f411a5e5c91cdc1af1c9348d7f42dcf7a0d9f801c2340d3aa690374295ab89dc32199102ae3e811bd9bd7ef37efc31589b53586d 1 0 \\x000000010000000000800003c09c44092da350e833074a0dff5f22c8e1048462f19c7a10b05b88d0a1c7b755d2aadc46db7f3a5dfe9bd4048db53b5f140e323a17319b0b0269dd2dbba9c89d35ee8ecfc9df85273e196d528375e02c7c1721fd3bfd268622bf585d2e021da6eb418fc34b74ac83826792253235c3adce0e56136f730521eb8442bb4b0b8c37010001 \\xe6fd0a52f090799c6c5429cb259fc3bed380330205f1d02be91caea0182bbf946cc23e8789009870a5226e715a4c72a408803b435ca8011c82250f67c8b7a604 1653469407000000 1654074207000000 1717146207000000 1811754207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-247 \\x3fbed50f580cd1c267967d9e7bc82ce152485e5df3fc5a5a30195df5dc681eafc82a1ddc9f875946a9150cb930395bcd562d2db6f81299bd49f60547661b2bc8 1 0 \\x000000010000000000800003a30b76ffe620bfeb5a86a41fe7dba17d771e2340c7fbbfbc8f6e5dd74206e87342148e7ba00e44b9a9d07d8d001169cca1fe678119f0783589ff2c0a018dcabdfdb281ccc3a8780a2229e462b8d3b23587150e9b9efb955683574e925e2b1811e183d6ed8275c3cc93cef4769ba39c7b8b35449447cf8750959ff52e18e42d4f010001 \\x966fac4c7f11784e4cc2ab4f10d119b9d808e85c3e098f7711bafe49f7c66febc033e32e055e148b401e8c7cb3f0be4ce366dde1b5cf6d0d9332dcce61e39c0a 1665559407000000 1666164207000000 1729236207000000 1823844207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-248 \\x43aa34c61acfb5705c773c73c6605026370dc6829583f84819e911a39e50a22796fe16570a54ae6b8a39cd77e56c9dc649ac924f0a0e4590189b567d41b39f7a 1 0 \\x000000010000000000800003e12eace89a501d611388caf123b600d69551387f553d80d05c5037438f6d16b953b4c553c94ecc7d1c8df238f525e327e7394212d93b34ed28ddf4c52cee963cdc5d9461e958bbfc73baa4caec7dc81016978943f0d0ec56322a4810b1ddadd016014c19448b2497765c5f78ae052b9aa173caa1e7df24652573798a4714fb5d010001 \\x58171e93a7988cd691b95bd6839238954faabec11920990e767e74e8a5558e29e6d77ff04f369dcc5ad2d193832e8c5b4609da5a42a6a9461b58f966813d780e 1664350407000000 1664955207000000 1728027207000000 1822635207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-249 \\x446a7b9ce596e4d5742142d8a6aebb313e791742b494c6e713f5f7d9a10cb076a29b24097a2e0fadf01a739057459e14745eae6196dddb87849d0728ae336877 1 0 \\x000000010000000000800003cdf719f6a6b23473415ed388ae302bdc570de16ad5387ba40b6c66c032ebd22392a18c8cfa88d2084979b2906681b966a6d604bfd6fcd5f9aed04489a3f44d3654272ba79180d4e30c586d19b4b16c296be5964fda5eae8891c6d9ca29bb4d336da18656d3866511cd392282ec5691d4c8c4db24b7fdc78b941ee05d3ebdc5d5010001 \\xc74d0f7bda350ddf9cc088669c5fd6d4ec247c09b13bac028e7fbd119b6ca6e72660451ee8694b8c18805897ca7371c4e0f56036d40deb7b04077575bbde8708 1654678407000000 1655283207000000 1718355207000000 1812963207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-250 \\x479e7fbbff21e25a76188b11e621e3aa4806dad22e229563e13413683f50d13935498de3ef40c8b092e2aebbb624185a53bf5947c9cabd7291d516e0e488fc07 1 0 \\x000000010000000000800003df5ea28d322aec5c5361b4a285d9bfb5bbc381b3cd3e7185430febb44a479e5d46fc5475020f50b1922bb6f84b0214fc4230a1062473cc63851b556aea9252498edc36c89c3a3e143ac3bbc6ac00bf07315557e0b14f8a957654f011d4bfd09c9bcf7ec6a6bb4d8b40059fd1c0df8f37558a5773ceb07f0fc993d335ea56731f010001 \\x4ac8ce9fa9163663306746ed1d5854e5ed3cb8a65554210e2d18c5cf8264d308206750fc0c39fe251799503b2f734c5f23745ece108e5273451b8e9dccf1f60f 1666163907000000 1666768707000000 1729840707000000 1824448707000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-251 \\x476a85e871b21620046fdde1277b96f9833bdd09d1878c68399804050cd21b3f71b0eaf546eba871d44e0dcf8cb55950e97b5e42ededa0b32bc958afb56de9a9 1 0 \\x000000010000000000800003ae831be3b9ec78a6341f88e753f4f490a6280c43f5df0adcd833ce58283d87f8287cdf41c9710f731543289d32423849e2ce24b19fe760738b1f0599bc9e8b53ca2b0e1b1d796116b3e133d55b3d012b0e955f8416c73f92ef2a44de278a758ec9dfd293857ce6b4fd07e4f9ae39c48c4c9fade634f6afb66036df107d81f3e1010001 \\x351eedee57b3971147e07d4883d7306a27cb177447bf90fbcba4b009b7004bef5c29cd20294f1d5ae55cb8c912e94798bb50f525ea046edacf9a06178b589c06 1650446907000000 1651051707000000 1714123707000000 1808731707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-252 \\x4b228fae8ee419be3dfec03dbc097fb1ee3736561be25ee6c9bc205a5c369e7e69327380e80911ed2d455783d59ed2d007418cc9246641bbc268fd834e70ad7c 1 0 \\x000000010000000000800003b4eccd3b762d2e7156ef7ed5749de58a34af2f8993647ee45d511c2db05b9d4e4d7c5de2663021e7a6bfb262cf933afa8f35589f7e6d37d33ffe9cf5ad9d3c1e3022e66c2c5895e25619156e4c9fa2b1401ecaf383b33749835949287361097dbf24c451b01545339fbfb752a50460737f029b43a2b69c3e2b140bf3eed79a8b010001 \\xa77d043e3efc8424dd03f826647b75bb695da14a969e8b30aee7aa511669efb6b15c23bb55036b1f9cb3981edab2b3338676e52d5e7e921f9b7dde2ac7636000 1642588407000000 1643193207000000 1706265207000000 1800873207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-253 \\x4f8ab01cd09e29c2d3f5ccb26662a313c8c1484ff59e5fff326538d4e3c770a1a6558026989a0e1db541a26796a6e001d0b393606326eea7afd2bb568f11e3c8 1 0 \\x000000010000000000800003b1bee88b5e4d32c42ad39556dc3d2a4b29e8588106f4de3e6647547f58531c4601a200774f0bb9c8b4c47c890e63b07885e6a3583d6cfddb8ed395d0a2f98cabe4bb73863e6f558938051c51a8578c66984054349fb56ec719388e5f7060a216468a82d54933a658bfc56acf8f3064ff69c545dda3d5565318a8e021ebd0da47010001 \\x82793f243978c49f73d53ff313b174a6a6019f4e3a81a3f1324bc90123616dd97d7a5148680e5a285b58d05ee51100e43606d43c2a4ca84a44da4574af77ea0d 1647424407000000 1648029207000000 1711101207000000 1805709207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-254 \\x53869db8700743cc814d09f2d797f9aea682ac2b26ac5c07ae81501406910f0e29d3cd510138836aed14084cc103ba7619ba7bd9373465bcd939448978af257f 1 0 \\x000000010000000000800003a7a8c62dc4651df44136d84d6d36f6cd34ae01d78cdd901b4be8a341e8908dd0ff7f1fd86736df5e993591d5a3b50850ecd3655073e6457aa0396ce0f768b2e86d9847a4aac8f3ca774ab1eaa74ca2bdc358538cc5da9b1fe832bafde5972b91b736714cbd17c49bbae0b21415657a608876ec6da12e06045a59d901a01a6da3010001 \\x146425cedf8c65485604b10b9b1bc2eb65bdd85418cb8937182493b61376ce66f720ddbebc304f39179aec36a20a8af3ea965b1a7201b320c259e656290ed609 1660118907000000 1660723707000000 1723795707000000 1818403707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-255 \\x53fe17148aab70d6517dc2736712746a28e6dd82bd01f192accc1d031754960c178eb2b95f20a25ebdc16c219212887230b58b039fa78738d9aae168a14e0fe8 1 0 \\x000000010000000000800003bcdb7a31f46039c38131a838f8acc6c22a2a3ac44c5e631359c7422236aa421a3812a8e1ae65747045a5d894b05a398f9d6fcf01c58a1a2504af22d5e642f354bc4433a68226488cafef1a294e5ef5306bc6e6f86c146313dc9c97e34a8a114ad897ff44784c5805d6d0418ab8d85e0d23d46c9a5815ba6254a3f16098ad8f11010001 \\x123208b53439847658aec94ea5a547736cf1f209161e85af94d772faee51ca308a364ef8931f2ba58ea11d5a2119e3ff49e564a3fe8332f2922e7e2bd8ff8508 1656491907000000 1657096707000000 1720168707000000 1814776707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-256 \\x5532432b0619791689d57dc04e77b25f3a2ec3a3b4b23a84dd9ad6ec5e4abe45d98fb8d8a056ca20e3b6105acdcd6976780b5212f7d72e646f36a43b8c2ab10a 1 0 \\x000000010000000000800003d6d3fccacc61e11fd884aaa896f6da2133c2fff34ed0f65b373daed0c7528c70c39914fcf10d9eced6915b7e10424d5b2aa04f277013b23627ecc8a4c8964958dd833977a8ada477f4be1f3b78728a1ec1b3cbcaaf765c56cc5bb92c1e9c25a35c594b5781d52350c48888ce7a290d4e27cf0f14b032b36a365032b6fbecb169010001 \\x7ea659a15b1aa859027b0e7c746419e8723f65282cd505da00e1855fe7cb346b0b7c0f97f3f1a26d5df3b4a869697b18f5ec4b6f56e096d328bae16e39e45703 1638356907000000 1638961707000000 1702033707000000 1796641707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-257 \\x553e0ff88a02120b92e37b4867974e13a830773fb596e48f0bc86aa914897db0027873b7cb14df0db2abd623593263c6276adfea1810bcd389fabaf10ff3b34f 1 0 \\x000000010000000000800003db7fcdf9e22f93a98da0d16ff8c0c98c713be3c99e426f36bdf0169f7ae217894445cfeda1773bd252ca60d36faf359bd0b5150190c77cb83c7e2f5d0b308228dd13c2f615c426be1dde28c71a4b4a5442264c2793a3342e7bc0357de2ce7b2e021ca1fb43a621045c5edc49e64cf138b93e6bf558e9fcc7efe727aae8882c97010001 \\x9d3b3c51ae3c9db76bac5f8bee132fbf1af65dad18202a981577df9c22ca96c114d34a9c6b1fd7b74e60a3b85eaf29e4e63d9553d4b2b0e11909bf7a3d512007 1643797407000000 1644402207000000 1707474207000000 1802082207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-258 \\x565e1b3473fbc5f69bfd45eaf2754940013de5f65a48b2417c8a879e8580226ddcaa3c80f841dbe16800cd9402b5ad2be9f7db8a0c94f4ac966e104807647810 1 0 \\x000000010000000000800003d6f3a97837687cf39e4e4c3333c4f0a2f15bc8ef38170ad7a3bf0a6da3747eeddf7894815ed06ae0f1c23a1eaaa7a0ff37a47a8be6d4bda84bbd80078f2bd2a727a0d5bdfba36f92ee6e45ba158353d4ffd01441be10514741ac958bf9779115fde77742a883a576e3b4bf355c184ede207b07199ce37fd6bbd43a8bb1ba9e85010001 \\xf7d30960dc5b575f9a2e900082a433b15e6c69c30779ee452cad4fc022d57f54aca6bf444242de06fdbe18c2d642bb99ea285e1d59d35c1158cc64b8695cf80c 1663745907000000 1664350707000000 1727422707000000 1822030707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-259 \\x58629f8622a7efbe75afc1c77cefbee983cd24920d436c9b8abd809ac426fd1415b30cab0138b20f990dfdded60196511cc2f7793826d7ca693df7ea862a9cc1 1 0 \\x000000010000000000800003ba361cf3eb28df0d06e889b9dd1eaeb11d7473aedc7988e45965244ab025f5658ff22708ce819212818d8ccc8d44605425552237b393a22ed675b39d9a8479bde3aea56c3729bcc2577c4663a322f9c0638ed9d304ffea664d7fc66c2d5131d360f50cac63184991f759f8e4dbed7087c5788a2d5f80159016ac42031368520b010001 \\x3638869fc98ac761ed4304ba5b76a96e70910f69ac571edf2183be6aef414640b83ce085516c9eaee53d69e4de43296fbecbf1b65b3aa04ff37253a4bc8b8802 1654073907000000 1654678707000000 1717750707000000 1812358707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-260 \\x5aea9c80be13587078bbc8767bf78479a4c778c8710d2babaebda9dcef3aa1e6ee9ddefd69ded1407640c23c3d979a441d83c86c68c07406464b0f55d3cc2c40 1 0 \\x000000010000000000800003af1bdfac39b742e1d5ecac8b26c8419836825496cc025797dc9e28f0c24df3cd7bbd023f0118044b1d1ec39465b449717e5487b315033b7f2096643c028c9beb703dc11e422f64775130e296e1cbab423664000441acc5356e967c6f4832cd02a42403601a21ceaded1da7eb49d64bacbcf6409e0f7a87b0f479a6358b14d9a1010001 \\x0c1d177a108f2c983307937ff561be048263caaa42ec46d0d4c738b9ea8c4519780bfbc84155ff7070881cc02a66aa38b3c80f36dbc28e1c23b1cca2b489a30d 1657096407000000 1657701207000000 1720773207000000 1815381207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-261 \\x5b86f7e532533caf0aedb91655ec1f74669a13bfc4675009d53d678af9e554f58cefebe360b77875f76b7177ae4e38f5a562b797b97637898c80bc062d7b6fa1 1 0 \\x000000010000000000800003eb4e52d3352eabf3495322f92b034e1a192d453713fd8a45b5c2d8a144329a5a4ecbb049e0f88cc58eb03a38e23fc56c25045473109411564d0617179e8acb657aac7f57a0ff5a620a53933ba18d54b6416a6eafef0c2d3d73b2d4ab0ec1c05e041717c7dcf051b9846dcc1e69614234fa40e10a100e0eee449849d253da7599010001 \\x41e057867605efd660472ccc4b8bc7f5098f31c39d3e61dc0aa06df0e63d960dab85f3a9b078f306f55e19f47e57bb7c8f94e09f5a36c2d88cdc93408198530d 1669790907000000 1670395707000000 1733467707000000 1828075707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-262 \\x5d8aea955c160f9c852eff39e1e7a659aafae2fde300dee6e77b6fad6987316246f411f4c8524b0a02f9722855abfc60d823ed10a34bcba6dedabf0c51f98e2a 1 0 \\x000000010000000000800003a0aac1c5dd73fa56f23a5076aa553c70591ab2b38ab347b29031e40ae3f3d72b527401ab63c36d9e143e40bbe18cd1b4bc910a37ef539d5b3faaa392e805fa2ee1625f32a3918589b10a431b26f2251e4a1d07b9ac8acf509362b2cf2006182c7d89b01ab677f2ec3c5a560ed58599f665037d6cf037413fd6cd5d9bfd78a2e3010001 \\xc9b9b6b1b9a09692d0cb0adc9dee6cfb9efd0db8db25c11a5c3df67e3faaef579fe215e5056f972c91df3886ae3d3cbd2ac96897d4e38964ded623cf1128ed09 1643192907000000 1643797707000000 1706869707000000 1801477707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-263 \\x5f5a4bbcb5219cbacecdba06c62e4e89b579484fbf659935f4d46d4bf26a4cff3b1ebcaf57baaaf9c3c2f3a7111d7b6ae7569d76ff5ded2c658bcd08d46adcad 1 0 \\x000000010000000000800003c04f4aef82a581ced14476f714bbdd48e2a9bd18b4601ea3c5ee3bf1c53fe59a3f3c5169599e3c062c6317aee441b4868f33318eec4a1ad124ddbec2a90d405340a4241e19e51c2004ef2a2083b1ebf28125d1f0ea663a9a0b85a6a4d5ecb27e1878cb9fc9fb05a7ad8e5e2936e119069b5375fe5ff6c7a76ce358fd4d7c6f59010001 \\xd4ea8285ca28e45d9f008abc22428d80052f54b2bd80cbe02e65b839a2c7df6e099a8125a05d1fc4f3fc951237b405138ab55e472de09d2dec4290ce3ac4590d 1649842407000000 1650447207000000 1713519207000000 1808127207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-264 \\x62de7888218737e4189b683860299ca6ed6e375804174514ed9c41a657260d73611e69dbeb34a3eb46bc079605d859e61385297133ccc2f109e3e0b64bdfab46 1 0 \\x000000010000000000800003d6fcbac531501818c86c8150e3bd5a125fff695307fec8a0afa4304251ef986288c08b0fbae029d0da6e80c9eef779f201e7fdafb37a726723c331b4d07b06fcf091df631e6ea9b055bcb63d748bca448b20953cd5bced1ba1c8e64fbe748c91031d497a65af26bab00becbb9b5fd2a21d6506106176d420aaf534423b4bbeff010001 \\xcffa583ebf7b337ba1958b80a267020c1a2900b7f3b54389da452bdfbe1c7eeb7051ed57e4c4b39b89acb51f3d68a76d00d76b3aa753663f4d212867d75bfc08 1668581907000000 1669186707000000 1732258707000000 1826866707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-265 \\x63fa503eec90c941070e704d06b70dd9cdbae14fbeb56415ca93c99cc132517235e98120e8932f4e3ee879c5f18ca119dbafe2d258ecbd5ab96d66433edbd3ae 1 0 \\x000000010000000000800003f938f484d39cb47a9102508073e247ebd4723afc3938faf76150571d5e0fed933138213bb2be06fdbc7e352f79e954b56aaa5b0d0c2e09f293a65fd820d3e1b6324d99c3fcef6fa27dee4684e43b63e90f50ff8967f728fb02d0e0ba1c7b4915d4f39d042c0fa5116d78a11d2c6a7ba8db4e0d3a363cd53bc708551afcb482ab010001 \\x5b8e60fd450375a23e9d2a068255ffacdf9f8c5b0fd1e5f07779de34653204a816b76426ee6f3d79c0b9cec93cc6932f659c11a7bc9bed9a648e80daf8d8750e 1659514407000000 1660119207000000 1723191207000000 1817799207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-266 \\x64c6225174aa193d51db51b7736f7c732ba73d7185ee281606208926214918f330400aa2c4764979f7c8e8b28ebee834a2fcfded15a76c85cbc742dde1d4309d 1 0 \\x000000010000000000800003ab6d5bac548749e434004a578a4062c9b1ff891209dcce1841a33c1840caae9e8ac9a0d3632e90585378f80c5292c7f506b54ae90f572a3e25448e8602379ce8adcc97a9f234cc03a67032b75ddf7299a99ca4004b28f1776ff4ef4fd8a5e347c71b786f7c605b5e957b1770e8b1a4506e71b109317a3a9335a023e2a5feda8b010001 \\xd0dc6650e7825f229ae66b1be824e8f334b1ee8a51f4aea06674d22e2198a78ca62772e5093a86103031d398406ea4236eea241cd337eec259444c5c89dc5e08 1664350407000000 1664955207000000 1728027207000000 1822635207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-267 \\x68aaa88de2a93ea8e44d4610910e1913d6d97c7c0244877f6a74c7da940ee87f1e354caaeed0d7c0788a9e6773412810dd069fde46f56e8984286adad9bf7bf5 1 0 \\x000000010000000000800003bc77bbaf57365a7088738f6c4fdc406dac62ffe55e6851f5446eda8e6255b5b0793b61675557800c544bbf48b92571d533b35f9e66fa969f4ccdccae0a451d578a93444e6e4940a0775d0db3542979726703155c340b1a577dd302640c9c2358a16e85e9655ef83e6505b34135a1fdec85924ed851bf1407102268d774e32bd3010001 \\x954260cc74ca392e4220195cb7b37ecd97d39f85fb9f72cd4af340cdb0b39a286d946016be3f29286104dc9272c13bbf32f920a6ed6233d0689364742ff07207 1653469407000000 1654074207000000 1717146207000000 1811754207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-268 \\x6b9e060cd1c14bcc38d622bdc5643bc16eed6daf751f3aa185ee42b4ae856e265ec7c303123aba5925b78575f9ddd18ba95445fd79c711576ed69898f828dfd5 1 0 \\x000000010000000000800003da5caad5151037c30281171ee06d1c8243b8e6e4ff9b6f75924426c4616c164eb56fce77b5b294d76a5a642810d0089df544a54cc9e4355d0b3c1af4a370512a24e8299aa1dd47fecf6568ac9d7e023c83a033c0a87d541ae966fdce8733f361f0622b631af8aebec25e18003fd23c2ce18e96c1695e802e874661c2b603a877010001 \\x6e57874c315cbdddc2cfaeb1d79b554407e0bbb829a503784dc24746c196db4c043b048619678d79bd89f1748f83882a2a5c98f66e66db630db6ca182b3b380b 1638356907000000 1638961707000000 1702033707000000 1796641707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-269 \\x6de26f257a500deb565c84d3a29d1d999f11ba8ad1981c1e1298504a5d2b6041a20caa43105d7b3683b9e6b9e7923b3236165c37b43a4e36da007880cea7e3bb 1 0 \\x000000010000000000800003a1635f7dfb468909d128305ecaecd734de2120d09cd6cb97889e2f290428b23562a9e8576f7c965b1f84da1f1889682075e71914703bbd47eed5668b46e7165fc1533646516901e982838f12a6d3c5e5a0a94de42511481a6378769d294047806a480e53d25cf229ba52e0422d30f660a289c951134bb6afa27f27e8acaf79ff010001 \\x8f759f32fb307855d152f109b6cedc584b03d31b85725bee55773213c1b27c142aa9e2fcdbb8595b581a46dd86d4bf41a84de3948b766c16789f136a4c8dd10f 1648633407000000 1649238207000000 1712310207000000 1806918207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-270 \\x6e16b37a03790ba720950b180670abab5f483cd6cddb3297270cfe7a19277d830889c81bf4d52e48295834c7fa50df52f5b154efb897b734b419d242cb54eccb 1 0 \\x000000010000000000800003eb5f374324930a2651ef467e06d19141328bc628d4ef6e86a589958b1ddfd9bfe06f07680928da32e0b545ed4dd6a1973065fcb14787673e478ea593926afd95036d77a90c99a27910756fe8eeb812e969deea429fc4d91ba2a429c721c19dc2352684115a9e76d71b15d3f75a863b0716de4a34f497d948424b75ea41703ee3010001 \\xf5200d57faf8722f5fff3f99cb9e387d0cc2c704e162234590d6ec391ee3b8643fd820a996c63a6920118055360a11d2198eed2fb2342dc17061edc6100da80b 1657096407000000 1657701207000000 1720773207000000 1815381207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-271 \\x75329549658318827e474098b2fd83668e057e32adb5d8aee5020a0d663607da61acb7734f10eb85d62cf573d229281b7a5e8772ffad2ab5b55b71c380b4693c 1 0 \\x000000010000000000800003cbd477af6ecb4646e81fc53df6b55b9d3ab2d408ffe52ad3f3ec9692153136ad22c9e59ac2b4758377857d8f0cfe467706171a59078682d98550fb6b9078391f09b4b9a34c6f66dc13707af4e1f9fdaed9ef262538fae293bdd31557b7f1c0a7aaf48e25781836fd98da0f3b8acd9dfcec52bde457e1f676c046ede9d88df37f010001 \\xb2dabc2488ba5941b0baf1301016bdef385f2b70123c4e089ec9463f46d1f8500ba8c052dde527e5098249814e0ef2817b55afdb1128a26e4064bdfcdebfdc0b 1659514407000000 1660119207000000 1723191207000000 1817799207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-272 \\x751ae75e268d34cd63ea39d9ef20cf518b38997bc31bfa55e087707ac477c615e1c294f8483505c8cf16ff364f30904259b42c95d0aa816e01b5669088d70f81 1 0 \\x0000000100000000008000039d41cb2d27543079cd2ee4a33ebccaad28983033f7ee3765c98199b33b48367f9d0def3c14d832053e95d42dfaa8cc8608f860b3d3519eb14a30bc4da23cf24449e78277060f85a373709ab008920ab619cfb66642dd9ceee088f0ff474eaa915aea88061610084b502cebd18a6cb4493f61cc04ed3b215747fc2e54a15474a7010001 \\x5135b6654197dad510a8b050a2bd8495af3eed5f7fd686fd1c6a0527f28915033febc0412932f02834e5b46990b5d012828f431d203daa6b16dfcc3b72a90f09 1661932407000000 1662537207000000 1725609207000000 1820217207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-273 \\x76d258f652d868972fef5de4b530560c5c70ccbba8e3e7caec50f9372d8b259ab0234c66141dcf2e06ddcc2dad2997465896ce9f3f382c7ca29fafd3ffd1b416 1 0 \\x000000010000000000800003af468a55c177b26dc58e442d4c4a961c3c38c28d111484f86289c3b43d2ad1d6692fabf07b1a421335d243cdbb8fe58f2147117e9dbd0ac814c18396ea84224727074d7eadb5f7e780b0ac89cf96308631beed4acba9ac3d56ee99292069556b053aaad9d8415bbd9af2e4e1ef7971625cecde2aa2b52365184d417aa63d87bd010001 \\x4a576ee1f477fc50974daf02a009f3da1969f7ac289f6de75d2999d73a7c0dc779096f0c213cb4ff1bde7bcb5ee644b534b924b510af20d63ab7a42841336b0c 1658305407000000 1658910207000000 1721982207000000 1816590207000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-274 \\x781626270d02461a773574a5afa829f18c62fd6811208ef731d317284eaf46722b0ee8f1bc10b2576a8bf24a25cabbc5d6c99b7170aee33ce086aec1f52fd014 1 0 \\x000000010000000000800003bd3ef0d94e8b8171137850d0de146d03d82c85fc969f29e4a388b65350c157ac8fb6f266f694f05b3f80dba0d5a5bead80109402e3b0699976d9e80add0ecd977447c417b5ddc7c818a4d796d38d1bcb76b4dfb526ad13b6b28b4a02c330472cadf1cb717c9fc80d4649792ad46495502c28ae5190b0ea9d9624c8fc8b67cb1d010001 \\x0fb81ed9ae8e1a3bc972768eef43d159e16fabbbf3510306e963342aeac8b9efa51a7d858b81a81ae3d74656a89dcad8b4310955256b75fa4585110167e2a80c 1650446907000000 1651051707000000 1714123707000000 1808731707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-275 \\x7b4e5ce066310dc2e649e34144eaa3baabdc68223c6bc489776204f34b0c67d2c4e638408693f837f4dcfc81f1ef3fe7180c969a601b57932e18fbd0865b1f40 1 0 \\x000000010000000000800003c5703c892d477e2d6d8989f35705534cf71ab738dc6e158320b877a0945e6a671cde262520d2916aa0095861378e6c35fc64ac6d6c15f970543adb79581f877b21f4fac8a0d9adc324d37d31fe8308a685d98e4eefd95b5d55282be9197075652b2a6134795470a4652e009209a07fbc8563d6ab79a965909e0731bc58bf222d010001 \\x884072a4884a40664e120fa4c40fcfa91d8111539c16e310df380ecc2a933609e557583cd033caed5796089fb81629a81db33b9aa78dafbb3135e9359b222609 1667372907000000 1667977707000000 1731049707000000 1825657707000000 8 0 0 5000000 0 2000000 0 3000000 0 4000000
-276 \\x7b56574fd157a252f7b3bcbf755d84ba675788335a475cba07f95d367a9fcbb00c596846e13544768f759bea696e25740b0a75fe3e1a13b7a249d731a4baa4f5 1 0 \\x000000010000000000800003c84c740a27f0ebd9f7318a665a1dc88b19a54e655f6263cc37b1961e2bdb3d07a0a6a8b084fce2288e74e94da08dd92368a04ded7d7af670c9e62fad940de3f7efd0e9650d374d7257ade8bb53c21a38162d13380c5b37817386319f53cbe5d5c1b51e218a90d736a3e7e0e7ff8053fa3059fd9807d92eff2d1d3ede1a44471d010001 \\x042970544bc20e42e2009c6cb0f24fb9928f00f94982458e73dbf342c86c5ce98d7a2f231cf3e3864d37da28af40cc6af5c37f2c2381be51cafeb1905e86dc09 1667372907000000 1667977707000000 1731049707000000 1825657707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-277 \\x7f52f35a97ddba3d5a641bc53f0ff6ddf8b0cd10dd43e4f12d8bf20df229e4cf01d392fd7b0f51dc7f054f9798d589e0a5d342d3981af42d914f3fcf7438fbcf 1 0 \\x000000010000000000800003d29a02098e055250021ae38351cacc9d0cd3646193967390340ff096d5c8346229ce82ae95788527b952d347d16e69d08a1db2b7fa4c0f454e303c28e35e104e1a643a7c319d9732e2d9e9ba7bda488c4fb4e7be49d6b5bac72b1b0ab14956858a5396e7d269014cfc85da79b0054d87289d2cc16001a0ff38d7499cc9ecd65b010001 \\x4624f5ad5bd06e59ace7ec2b9f0e57f14deac267b4a7caa5f488ddce0083f2285e9353554ac191eb934560ad4afb99671c674b86154e6a875adb048a6d704c0e 1643797407000000 1644402207000000 1707474207000000 1802082207000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-278 \\x802636136b909fdd05bdde9e17d591c7efe93a327f90d8c8670019103473c9ae225e17ac715ecfabea48a3c51f55deb1d7db05cc6475c6c7f0f20cf0225de9c8 1 0 \\x000000010000000000800003d202dde1c8eec1a3b31e2569297620947cd8e6b8bfa144ef9ba2924c7989877d5a02e54bd6db2ab45d1ac2dabeeb6db6dc61e27839ceea1596d799e70ad7f9b445ba51bf605b2e324cae88ce8cc4b935547c640eb9bcddcacd2d3230e414510ce52fad845c112bad6db51c643966ff7c91e71871a70bc705d412d4f92dc04ec7010001 \\xee9bc3bf7dcd6e2ebd5d7155264b4e1f658e4f81668fcff017de27f5b650e2acbd4df1d261bd5c226f8fb690419d1aa252891fa7829b56735356ec65c2f61703 1661327907000000 1661932707000000 1725004707000000 1819612707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-279 \\x846686ae6dc00a82c3e46e1947da63f32cc78d6bfdaa7c24c7691414a38a6dd036b26e96816979d2ea472052ab54d3fc7e577d880a5c40d81e4e647dc0b242b8 1 0 \\x000000010000000000800003c27732175dba75748a7911b3570582d414518b93bd17b6b862d92fdd7ead41a5754f477d02b24cf22d66c579fd30e06b776a79ce3272e93ca376fc0c2e474b7bc99eb68ae05330da42e0b14aa891e6bb8ef269c06dc029abc05ada76d4a9b193c3a602e596c5b707f605deea69eadc4e1477019e1860c791f6492c7e8fedc909010001 \\xa565f43436f33481fd040c4533a513172ea581b1adcb23c590c6cc8ea6a257042845b4a081938506399262fd450cb6cba1fc3efc5eb1829c0e2237d5e332a50b 1656491907000000 1657096707000000 1720168707000000 1814776707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-280 \\x852e63d61a1da7042f9349987a725e67092a29b14a89cdf06e3db865f925d020ac70ea6bf4dce6a411b10face7cf544af22fd60f4480b97ef48f9588fd511952 1 0 \\x000000010000000000800003c7b26fd4e6d767c7afd6b9da077c3ed99b97bf77fe6adb625b0b41e069e721aa0b6f74b7dd8b7b22e010183ed84a6ab34a0dd31534f305615789652f3fde62ece2a33c5e5bf40cb1e7f4dc8a4886b0552eeba5dc910d71bbf653c2f2c9de72bc2500d2ff78ea5c5445ccfdc436b1d48cd58e80653ad2484b1b4372581279edc9010001 \\x2db7ee95c9c0aea8683decb46917bb24b0ed275f9773be612ce45d267e1c74f721b70cc6da01726bbadfd597d4f4fe1883b63ac11c7ad7b932fdd1cfe34c5802 1654678407000000 1655283207000000 1718355207000000 1812963207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-281 \\x858efb3cf46740dac0a1f4a268b35bafe95ad61ca5fde745b7a006aedc190d853ff3479ecc8b683ffc30004a46a46ebf27b0b729cea22d9e6b152e2ec5f2c283 1 0 \\x000000010000000000800003c59aa71f0ebb840f2afee250bde633a658d1043b9ec5aa5ba32085da48eb52033e41af9f00352c1c367c0c8b23eb89c7d06457f960513a65864fb59c494b2ba7f98646b7b4ff6d6d9297d28d47e0abdab5b20cbbc2cfbd99f7b4216469699697438df8f9773f57895cdf4990816c8a86a3cea2e7fb3e195ad7141add56780323010001 \\xbbbc4ac24eee9ab4079e3d0a00d21e06e3ad9850e495a9b23087c5eae55db9c9be4fa21ae8990d2f83b633f2bd21d9979b75b4fad63611f78a2d260fefb8e70f 1664350407000000 1664955207000000 1728027207000000 1822635207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-282 \\x860ea0031ebb0629c85f9df60f60a7b2cb276a24b6c6e792afdfcd5e329eb9e66d8162ce351c869ffc795087650c0bea9d98ebf237b58f3a35e7739c96dd4ba4 1 0 \\x000000010000000000800003ccbd4e55b81e8ef79fc229420090aa2a4fa2a7133250bb56674cc80f842aca5994baf42297dbe848af3572799aac2db795cb087a28f69d26066b53cac06e4028beb7f7e958fe84c313525645be2b6e157799e201d7dc04df8af95b77767ff23c33735610bc5c6ca89ec891e1d675ed8d10f28236f896d878bbd172cb9b9cffbd010001 \\x099c77100b2b892b72c4c9e08275dc6afa4e8dc8dd64e7b5433b60a5fd66e58dc8d5ab108d88abbdcb63da13f6c77372b9abac148cc5d51145236498c048a508 1654678407000000 1655283207000000 1718355207000000 1812963207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-283 \\x87ca7d03beed00a1496c0a04c9e2b02a234cc8d2fa23f7d5650cbd630e2d0526a72d45a2e2c60c5486ae2a94365dd15f4489301f0eb4e8c6071c67b8ac417aa1 1 0 \\x000000010000000000800003beac4553f39358ad875c33351e67fc2eff5e5e64e31f77258af111b4bb3e0362f4c00b8dd7f663c9b5af1bd193a20b3db340805239653d2fe5a3c61bd1e6b8939e26e14560717eeb4ff651d6911555016c03c5386217878884af92f8ff1ee83bac5c3f0a495e13c1faaefddd393058b68bd7ee1eb142494c0e8d4c670f63c871010001 \\x706e8ddc5bdca867f125a125e1c4158d92f91c59c94f8048dd7d7cedac8a8deba9b546ba12023960b90ade3b21f6930fe984ca303209978afe5e94c5168f1d06 1659514407000000 1660119207000000 1723191207000000 1817799207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-284 \\x8916454d1c3cedae4fc6dea96c002c9cfb12328fe718d91e772f3c4483bfa2c1b4dcf47ae72a8e70a825f186ddffb76f7b15bba737268ff6a500453908fd8ab9 1 0 \\x000000010000000000800003dffbf1b98343567ccf17fe1d960d26ef802e0a9076a137a2e5c80995b5d1936730a0c163bf0b410ff168c4e1dd9220b56e5b5fd22bffccab89d20c10df63be283f7c582ce5bccce6620c05a17f5e714a3a487440ccef2e33e4c561c7055ffaeb2230952f0b0c7774a66d0c2dc81c67269c40b1accf0d950d4be70fc36c4d239d010001 \\x21090e46d34102136e7fbff12918a3449b2e927c39d88068715216198fbeb06f1780540105f80db390f6367b96700d9f892b1f96170880ca6a1af459305b420b 1663141407000000 1663746207000000 1726818207000000 1821426207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-285 \\x8b2692d68303279e1617e883ad4c02e64690be5ef76d511ccf18894fdc6fe250ae64f722b319ecfc867fb8e5943fea75857542ec66c82b8e6218ed5a716c5b99 1 0 \\x00000001000000000080000398412ff57d5a6652f17501a848dbb55fd7f19d50b078b7ac7180462a1e23e91fe4b30be8aeaa05fa526239fc7273de282f98b32603034f514180736a64ad31e5cc78db9f5e940da235f608d1f37327c0614502c9891b450a614517b078a80f80e5d7cf7ecab6eab7f814db16fa40291f68aa652cbff17cf2a9cf4a61d2e1edcf010001 \\x6c714305107588b335685d860fc471bfd8017492c28a15ea87d569929a4285161fb3de27a045620371492796e4b85232ecf732004c799fea2eb781ca5e7b7307 1646819907000000 1647424707000000 1710496707000000 1805104707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-286 \\x8c160e85c1eb38d824177079910b6c33e50d95999209a28eae5f1a8baaaa750738a5f207c8a5b53d9880321504859faf62ec509fa208ac1a24bba7c3a2912a52 1 0 \\x000000010000000000800003d68c84dde91d1e9871ba839f7ef5ae0b93843bb6d4b92d32194d7386f9fbc1fffd257b9a2381f18f301c35c0573d6873ed7cf144077372ddd98c57766b7c56fb6fae7a2409a6aadc84fe4593f3ce869740826e2e26ae97b2d259d8510478f5d301571d3547133107faeee671f8754422c68ee310e30dbd1046a2e2ca820dc9ff010001 \\x636b39a1ce9b61a3a6270841cf534cc4164aed76a13de85b429921f84d1a494318504b08ca6fd120c4ad89e0608a03ac6b3e6702a0c50a4fe7169b79d79b3d02 1655282907000000 1655887707000000 1718959707000000 1813567707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-287 \\x8d320397fded1709e5e01a8f7ac01dbe181140a0f43dc3fc01dd7188626e62eb62444d2c71fb25a577b720bb1952f1bd0444d6b4af38e4c54018a162f1dec658 1 0 \\x000000010000000000800003d4d8cc4622469e48fc90fe8f7c204868fa7b3750216f124d276309efdb6dbe7f64dbd6a63dc4d962a4a4f45e18e55dfeb8247197c503fb278e70da6fd64bcf51c9ae4b9a3e879418bb14a97578cb4e2e47ef47f0e119f45f74e64b61247bb6e1c04285bb9b0d291f39c91ec997c5ccab21c888c6a6244aabe290950bf29162f1010001 \\xca24336248736c185169648d9f444198539d161cf22b4ba856233b92bf67b9caca386ff61a7c339af91e4f5ae4eff6523e5b07672d3e606180bd6591ba4d480a 1641983907000000 1642588707000000 1705660707000000 1800268707000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-288 \\x908e3d2331b3bb18b35501b6665425e3e45426d59109c385bdac76ef715fa3fbaa3af0c4ebcedd2a04b0e907a9ebf9158eda2e911e34e1530ce5d5e0688f1b24 1 0 \\x000000010000000000800003b5ea0755fa2457a349a7eb1898708c7a603a64b0ae1c25e81dca75ab5a579898ddbc10520cfa78188a7c9bef4421ec796cd4ab664e390c8fde6e77a9f35353749c11e7ed4fbba1b789fe55cade02d5df8ba6b901df748f5bda0d08dde9a3246785bf394995fab407e7c2df787f179c7bc35ce65681a6751f5b412686c7d77c49010001 \\xd2baba2014a9c8e3e72e3b9b88cbb763b825d8c465d3f82cd1a3ecc7e885c0cd95517dfd3151bfde73d121fda0092d7acc01894d4a24b958a65fe59077577f05 1660118907000000 1660723707000000 1723795707000000 1818403707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-289 \\x952219e9134c5f5a8f87fe0f1ea754ab28280a39011f1d9b2a04008906bccd3270260d7bb923e656dc3b00d33a606e24da72f24ceac12ee6b7ed1f31d4fb4023 1 0 \\x000000010000000000800003c3e73870605e95b7e135a20089babfb54bda77b93c4a1cc42f5527326d51badcbb8849304c700b377e42ac394db60f3e49b97db786599dc7d2a42b022695ed7ccaa9cb89005aa3d000f4e5dbda4385dc535bf0835040d16bba8b954deec94860fa66038fa82ae32356482d3fd1f0aceb290d9b05f72df07336d86775c71d887d010001 \\xe42ac66ab7c8ddf45a726d9b5bc6f131aafa2e3ec46f68af6f5fb9a4945c322a929ad3f2a8212f93e0ece561e76086eb7058c5c4bdded57dac049b4919fb1006 1641379407000000 1641984207000000 1705056207000000 1799664207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-290 \\x979eb71d6bd24e30cf65ee5736317865cc81c9fb2a19155951ccba2a6f7bff3f3440c8dfc5df7451f9c7e38e5e2449680abebe7ceceafee0bdabffe903def43e 1 0 \\x000000010000000000800003ec6d703c4a7487dc153d2252a23e367eb8c4354e8cf7841fecc5c36a2eac6648ad13f1635d5df84ec7032a7d06ccb012aa83c4f7ffcbc4f8dcd457d269cd6d77aa8cad2446be1d724fe61f4719bf63973d660b25e3e4bb6bfa6581e71c15acbc51475663b8a0ea3bf8a82d4382dfa5ada405a81ad0d697ddccf01ad4d11f241f010001 \\x6ef4aae8e7df5f4bddf226e0cfd4275134a3a4d6c4f983497f87063d08d0966650294efee3889049308599f1b62c79957ba71e2ecc1d3d8ff1ec5a34e938da06 1654073907000000 1654678707000000 1717750707000000 1812358707000000 10 0 0 1000000 0 1000000 0 3000000 0 1000000
-291 \\x9a929d4069ffe77be2334a11a2636be5eb5a294c1dd2593d5f954167a2d4af77c731fc58f9f10a2f6e71a6f879737ba3759b0f4acf3ad21ea0a9c5c7cec9fb40 1 0 \\x000000010000000000800003fca58e23b5e5272aba5c5a7e2f1dfcaf81aad9193c79fe50ee2cd48a06738af5f5c0a7768a2d775602419ff27652cb9f6196e518da9e85793519c4a40fc8ec45ea93905ce7fe7300aa8264661f60f96ed9187e8961bc9f850d93af5e0b00ecd3dc26571ee4fd9dd6737ab329876eea8c3676adaaa062f9ecb2c4541a9b7b210b010001 \\x456a7e65b54baedaa895b7838297eb2ac3e88cf25b22e23bd71409358aff71ed7786ea2e403b1127228da036e4bbe4078c45ef23de1b48d8641c74e6b66d3603 1657096407000000 1657701207000000 1720773207000000 1815381207000000 0 1000000 0 1000000 0 1000000 0 1000000 0 1000000
-292 \\x9b764ae50d05b10007961d5f0df545bcb5f326ef245aa7b7cb015b88a07c76185c7b5a669979e4df3ebeb1c46f76ba19a1ecee7f498f5e97774062a4f658b3cb 1 0 \\x000000010000000000800003a021627ec974533f8fb88e8f40d59c024f81c95ea80a5cf9e38816d00b789206db41b5fa86be62f7ae8356b648a03b21100ab9c30aea932e816cc74a2a4fd44db3596e2a658e50aff0b35194339d61ec2f71aad1fcea205c8e2019b75b4cb0d358d17136afc21c7b3aff637ca149c52d42df51055a9e100fb20ea52c0039b835010001 \\xeb08b7b5480f7f5462c2b0ae557ca41933d6281bb2a63e6eae12ce7115974e51d7e251355a69b16674d6394524ce59076184180072c4ccf5459526deed8dcd0a 1641379407000000 1641984207000000 1705056207000000 1799664207000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-293 \\x9b2205e2db384d02f28550d3506c3a96194e8a56318e23792522966591519051a3982ba958ed340cd5abf5c148f3870a9b4b960b0605e3df1192e473f8baf412 1 0 \\x000000010000000000800003c4288e0554713ad30711d87ef45f45222fb98db467bb369672f8ef42dca060d98c38b5c9942afd0ccde98a51eec8311e40b97aa96c004795faa913b414630f133a216608644c1ec5f944ef1be98b40b5cd18f7bd79dd3e757eebc569bd78cd6981f8570361d8b17d14175c17bbfdba4edd2f928122ef21addd34fac930ff6245010001 \\x1a46fbd5083745684c211af1e581bca65b5d30e54b626188edaea6e660c8b9f9d60926720313e95f0e98f161efc364e52f5822fba3eae4da1b33cee760a2e904 1666768407000000 1667373207000000 1730445207000000 1825053207000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-294 \\x9d22954fc3104061aa1caabb09a2a73679e448c9f16fe96604421338fb6b8be64caf6bdec3f2a341a2b81d16c62d0d16a313dedf31f99918600801348dd34292 1 0 \\x000000010000000000800003b95ad0ca87c15f1efd9799ae5474fb89a98fc083075934344aea35817a8be44d5d2db70b9aa11163e27d8c78089b3e4e51324fe4cb8ee71f89a4cabcd5913d3d941a1f6f5f34da8c997b6bf1a0c2bb7e5547834d6422e52e34fcbf7456f8daba42319b3564fb9b9dbaa3549fd2b7c22a7610e5cfffc9d156c079ebae925764e9010001 \\x5f4fedf65afd3e4de4dae56bb864106af40a28abb9f34a7024a946ec317324a6c23a0996c0df4f576272f8398ee705965e59ca43e4bfab52ec8d1c40c2ce350e 1641983907000000 1642588707000000 1705660707000000 1800268707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-295 \\xa022b210850abba1d3b76113806381bb54855338c5f62107877042075d92623c777a9215fefaab764962be17af32c29bc4f3e2010d38bfda2620d942dcc96686 1 0 \\x000000010000000000800003c68eff8c38dc6d7dc6a7752daf5bf5c9bb0e014c49168c17dce61d0465104d7d0160a39cf1fef9dbf8d19bfecb5cf1569b373c7493318fb717912a1f6a35bea03ba8406599374a91c426b7d09e7cb9a0b0466c1bcd2e6304770f1f113c9918f1c3b97f5c6d8d360770570d75b6a70b4c2b024233219b52cc3235aeefbf50868f010001 \\x767f2162dbf003d8caf72898d06a8277e7786815b7e0b2c8a01a086e76bbdac6d05a52106312027db74338711f21ee5cc974377da9f5e99735d5a6695052f500 1641983907000000 1642588707000000 1705660707000000 1800268707000000 2 0 0 3000000 0 3000000 0 4000000 0 2000000
-296 \\xa16e43842fbb2e1c63e4d5ee28c03b6a43c17d89787121a41773650c5ef0ab328682c5ac5051842a3af87605dc3db4298a4f91b1d414774e50a378aa99e4c7b8 1 0 \\x000000010000000000800003a51b5f98e2004fa23e4a33e1261e8204f202dfa0294edaa9ee7199408fc4ef54bbfc83d2a0b4e80fc33fc5174380959677d0c5ca0dca54a1e656fe316859a779f89178fcd781ac04ca51d965a58d84679eb5302547762e0f4cec0382c578888e0fbfc3689fca50599f55e33bde3d4997517522a1e134959a3af7f1363e814607010001 \\x61899ded2e8a18cb0816d5b02b6dbd43652119a207885c1d4656fea528fc44fef71050a322795daa1699317526a9dfadf86e22b208789d3d75b80e06acc73000 1645006407000000 1645611207000000 1708683207000000 1803291207000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-297 \\xa2c6170a13d4bdd2b33b261a2589afcff909ca35ef1d286fc174046bbd4ef50efcf0aaf7e11fdaffc76520ac3429e863567443251a3df5358ce47780059251ac 1 0 \\x000000010000000000800003b3c0da469b0bc96f64b1f0ecdf37677ccbd94f11b7f3a182a802445d0bfcb1ad6ec7a27a2d7752b45a40c73c190514ec5ce95748adfd219ea1cffbc795c60384accb1f5623b0bb0d3fd11ce628fa5640d169669fef4eb04f46c6132706eac21717804f34e5e2cb61085365ce48c96b1ae3f51036c7ad0fb527533f352c1f8ac5010001 \\x93c79c5a545ad37c5d80f69d311a4eb1ad5ad409ab2597ea19ccf8d829a359992e7c93a0d41854ba678ac65b541c01d2c96a23232ec43d29dc1e5636bfcb6f0a 1663745907000000 1664350707000000 1727422707000000 1822030707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-298 \\xa3be61b60a777b81d434f388f84f281d1fbacd8fe044fc36cff7ed4a4c601289fa0186a00d2ce05a08dc52efcf22453db8c8519feeb4e8d7b49be51e4626a27c 1 0 \\x000000010000000000800003d3f2af00f1f8cbd3eccfc078f31d865fc7b234fae6ca1b9f6936ed66b4935986a459ecf9f0ef5454338f22acbfa5f86033c131ed73a1794096af1cda0548575b07d1ed7992a7fb04a95e35dce9d367464431ac6b10234caa933405feaa41fb94e4722d574f73cf0d0ab0f9a5d0307f86c47c01871420344e920d68ec7e687049010001 \\xf57aba962f5f5f02444b4d6704e8a3d4db794aab5b149f1bea61fab49c347377001e9ad559a959ab89af0fb82dd5be2633878b10415e1611c2eba7b38ff87007 1646819907000000 1647424707000000 1710496707000000 1805104707000000 0 10000000 0 1000000 0 1000000 0 3000000 0 1000000
-299 \\xa5e2841f476f3e97ca8b45e959d0e7312d88da504d0cdf47e731d216bb1302dd370e0231bb96175e57d2a8af2f3d58ce944e269fb7119273b7599c02c8d4b24f 1 0 \\x000000010000000000800003b3a4f02da25eaa9ea7736cb014096eb223e9c259a73e716c712d09b2b82409683563c0d50f3aa733dd8be583402a449a9b9783cbc4a7355c2dcfc5d5c6ae3ce00c95c0c7a4238e949897013526f2f1d410643d1b96b76a3ba98e8e98641c3ce9de6dc1e9c7dea94ce73031299fe33f1f6d5109ac12bcd4134cde9c75e03ceb67010001 \\xa7a3eb7446d8320cd64291b668f1b12f7c76b3adf794895043dee0f81809309f46aad09c429e0ecb91c503793e8a928d5e577eee60d0d8c25912e73d2ecf220d 1666768407000000 1667373207000000 1730445207000000 1825053207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-300 \\xa7be193ebfe07faaa3aa7fd3806f82386101413e1a38ef6dc520bf5b0c631831a291148b7e6f9589bece7ab54a2aa6c3c1eda3b376798239ae4c643a8fa06629 1 0 \\x0000000100000000008000039ffee1c5c8614103c6d43bd51698080ec86dc8bb5d53dd550684965304c2e6313d69b31db5e74f072720f1deb01ef6dd6ccb4c6b34d393e392b810be622ea9b7c7aa3ff009cecc41e61b11c3e752764f0f4a1ac751125ee12f7bd80c1fbc3a3b5319a04024cc488f643217e74d14b402b54aea17b04001a831f58e8edc942cc3010001 \\x4d91eeddc8c48a96049fc14ed9c04a7b51d243be942d9bef0578e3fc647df58f0b79e076a7d65a98f4865dda046482f301f21db7a4c1ae4275f7defdfdd13f08 1643797407000000 1644402207000000 1707474207000000 1802082207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-301 \\xa82663324569f4e695737646b49f096ddbce80b11639b5cdfa90a7beca2798c89e98f8876c4d01c7d47da5106ec14bc74282ceffeb06fdf63ec1e7006d145c1a 1 0 \\x000000010000000000800003c0f07e97a797ceec713dfd1d38d40f123dbf82bc7c2de7197e395c7b194b2ac1ea1e751f57a65806eb87cc1493dd4d51f57e5e2202f317d148f3fdc690187d084f88f7151d6bb6ed273049dbf056734cef0acc6902a41b924dad0e58b56d7251c8306434c4c07448b4713794948d5d974bc749de15cb9da865ee17dd3db296d1010001 \\x252e195f8f06054ac438ae20cd05f9e0ffdbead96081375767e0d6baf329dbe68e9059cee752783fbd87730ed452f438fc2d99aff4b490b15f9806158e341905 1651655907000000 1652260707000000 1715332707000000 1809940707000000 1 0 0 2000000 0 2000000 0 3000000 0 1000000
-302 \\xabaaa3d90610973f03d08f044aa377791642eac7cd8252d3f27c49147b156b581a732134528acbb3c2938eb8ecfbe438e5644172e62ea7837aca07b67c7377f2 1 0 \\x000000010000000000800003d795c2b021c6d6e33a1fae3e015a3c29c24a59e2212c5479648cc1fa467e50d2f49b3554844c1c5c0121baa785b52293a61217d136ebf7efa59ca915d871f32ad05fd4ee6f9d36dc908ca49d166dee23a97201c5a5f0658c51be9d5515abc9b695d642511f3e914493dcd8bd4e4daa0b7fc37d3d6bf957a072e853b9f369c717010001 \\x64a1a1c64cdf103a9fb6c7fcfb24ea75e348096d9fdc3a6e64606bf0ee8cf74eb476c06be8bb8a19c42b8033ca4a685f40c6c2c964010140dc3b14ceed1df705 1643797407000000 1644402207000000 1707474207000000 1802082207000000 5 0 0 1000000 0 1000000 0 3000000 0 1000000
-303 \\xab86b5314f48d4093d0d0e18d4919df1227ae2cefd60f1ad3b8e8e8b96494c36ff253911425bece27f696880921c848426b265aebbc155761bd1b1c7c9001876 1 0 \\x000000010000000000800003ce1f6a1d65cc5eda56798c8da166ad382dc85dac9864ea0b599839f16c4ab64d0f6ca3e4f8291f7e5af27617e8326edfdd3e00d6bf5abc230738783f7f460efdcdfe54cbb4fbd4aa0e340e9719113c08cc0d6c6b2614e4d5d2be5ec6f53ddda9b3423bf4e2da8eca8c7c2418f8bfcc825a58e445f7bd85134c1874a5913a2ed9010001 \\xbf7c510d57a9d62eadbcdb8d2b050e2543c68f7f6cd5cf391aa6f66942273ba7813dce0211978283874c58aae05907e6a27d40216be01a05a59a7b3801581b02 1646819907000000 1647424707000000 1710496707000000 1805104707000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-304 \\xaed66316c2884faeb668a738d6548656c48a9c27a4389737d5baa892a92238cbea0b2ba7ef58ab28786d3531021fb50ab33fbb90ecca96de3793c267c113bfed 1 0 \\x000000010000000000800003bd73445aaecdf7c30f8c70637bccdf9619a1b8e5869ba7a6b175d61cc0e9877f60a226dafc52062188e2a50de85345a3d68d7d70387013b773d2c52f19970a773447dc8a416e16a261ee86359f0ea9a292437393ed25885a6e9714ab9f837d6c8265b8edeae8841f0c4c4e61027c11837a3d8ab1733288db9d669aed26dfce8d010001 \\xfdad83f9335b7f27dea3ec67ff8aaa07afd706f1db2a78e44b092c1d7b0cbe251da1d0ab8c8fc50507132bb7639b1c65c3e29bef1a8ab501b7051a9cfaea1d0d 1638961407000000 1639566207000000 1702638207000000 1797246207000000 4 0 0 3000000 0 3000000 0 4000000 0 2000000
-305 \\xb01afd642f205936fda19d5f85c025c7d653a74120868e7569604bbb18015a37e584e894